logo

Op bereik gebaseerd for-lus in C++

Op bereik gebaseerde for-lus in C++ is toegevoegd sinds C++ 11. Het voert een for-lus uit over een bereik. Gebruikt als een beter leesbaar equivalent van de traditionele for-lus die over een bereik van waarden werkt, zoals alle elementen in een container.

  for ( range_declaration : range_expression )      loop_statement    Parameters :    range_declaration :   a declaration of a named variable, whose type is the  type of the element of the sequence represented by  range_expression, or a reference to that type. Often uses the auto specifier for automatic type  deduction.   range_expression :   any expression that represents a suitable sequence  or a braced-init-list.   loop_statement :   any statement, typically a compound statement, which is the body of the loop.>

C++-implementatie:



C++
// Illustration of range-for loop // using CPP code #include  #include  #include  #include  using namespace std; // Driver int main() {  // Iterating over whole array  vector v = {0, 1, 2, 3, 4, 5 };  voor (auto i: v) cout<< i << ' ';  cout << '
';  // the initializer may be a braced-init-list  for (int n : { 0, 1, 2, 3, 4, 5 })  cout << n << ' ';  cout << '
';  // Iterating over array  int a[] = { 0, 1, 2, 3, 4, 5 };  for (int n : a)  cout << n << ' ';  cout << '
';  // Just running a loop for every array  // element  for (int n : a)  cout << 'In loop' << ' ';  cout << '
';  // Printing string characters  string str = 'Geeks';  for (char c : str)  cout << c << ' ';  cout << '
';  // Printing keys and values of a map  map KAART({ { 1, 1 }, { 2, 2 }, { 3, 3 } });  voor (auto i: KAART) cout<< '{' << i.first << ', ' << i.second << '}
'; }>

Uitvoer
0 1 2 3 4 5 0 1 2 3 4 5 0 1 2 3 4 5 In loop In loop In loop In loop In loop In loop G e e k s {1, 1} {2, 2} {3, 3}>


C++ 17 of hoger: Op bereik gebaseerde loops kunnen ook worden gebruikt met kaarten als deze:

for (auto& [key, value]: myMap) {  cout << key << ' has value ' << value << std::endl; }>

Hier werkt [sleutel, waarde] als elementen van een paar die direct toegankelijk is zonder het eerste of tweede trefwoord op te geven.