Je me suis retrouvé à écrire ceci il y a juste un peu:
template <long int T_begin, long int T_end>
class range_class {
public:
class iterator {
friend class range_class;
public:
long int operator *() const { return i_; }
const iterator &operator ++() { ++i_; return *this; }
iterator operator ++(int) { iterator copy(*this); ++i_; return copy; }
bool operator ==(const iterator &other) const { return i_ == other.i_; }
bool operator !=(const iterator &other) const { return i_ != other.i_; }
protected:
iterator(long int start) : i_ (start) { }
private:
unsigned long i_;
};
iterator begin() const { return iterator(T_begin); }
iterator end() const { return iterator(T_end); }
};
template <long int T_begin, long int T_end>
const range_class<T_begin, T_end>
range()
{
return range_class<T_begin, T_end>();
}
Et cela me permet d'écrire des choses comme ceci:
for (auto i: range<0, 10>()) {
// stuff with i
}
Maintenant, je sais que ce que j'ai écrit n'est peut-être pas le meilleur code. Et peut-être y a-t-il un moyen de le rendre plus flexible et utile. Mais il me semble que quelque chose comme ça aurait dû faire partie de la norme.
Donc est-il? Une sorte de nouvelle bibliothèque a-t-elle été ajoutée pour les itérateurs sur une plage d'entiers, ou peut-être une plage générique de valeurs scalaires calculées?
range
fonction de modèle? Cela n'ajoute rien à l'usage dans lequel il range_class
est utilisé. Je veux dire, range<0,10>()
et c'est range_class<0,10>()
exactement la même chose!