If a class provides begin and end functions returning iterator objects, and that iterator has a != operator, then the class can be used in a range based for. Here’s an example that allows for iterating over all the bits in an integer. For example, suppose that
0b10101010
is a representation of the set:
128, 32, 8, 2
or
1<<7, 1<<5, 1<<3, 1<<1
We can iterate over the set with a set of bit shifts, and use the following setup to do so
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 | class bititer { unsigned bset ; int cur{} ; public : bititer( const unsigned b ) : bset{ b } { } bititer & operator++() { bset >>= 1 ; cur++ ; return * this ; } unsigned operator*() { unsigned v{} ; if ( bset & 1 ) { v = ( 1 << cur ) ; } return v ; } bool operator !=( const bititer & b ) { return ( bset != b.bset ) ; } } ; |
Iteration can now be done once a container adapter that provides the begin and end functions is implemented:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | struct bitset { unsigned bits ; bititer begin() { return bititer{ bits } ; } bititer end() { return bititer{ 0 } ; } } ; int main() { for ( auto v : bitset{ 0b10101010 } ) { std::cout << v << "\n" ; } return 0 ; } |
Note that the 0b10101010 syntax is from c++14, not c++11.