Une possibilité pourrait être iterator_range de boost
(Ne pas avoir un compilateur qui prend en charge basé gamme pour, à l'aide BOOST_FOREACH
au lieu I. d attend que la plage de valeurs pour le travail soit la même, à condition que le conteneur ou la plage ait la méthode de début et de fin.)
#include <boost/foreach.hpp>
#include <boost/range/iterator_range.hpp>
#include <iostream>
#include <vector>
int main()
{
std::vector<int> v{1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
BOOST_FOREACH(int n, boost::make_iterator_range(v.begin(), v.begin() + v.size()/2)) {
std::cout << n << '\n';
}
}
Pour plus de commodité, vous pouvez également créer votre propre fonction de découpe, de manière à accepter les indices au lieu des itérateurs. Encore une fois, il pourrait se fonder sur boost.iterator_range, ou non:
#include <cstddef>
#include <iterator>
template <class Iterator>
class iter_pair
{
public:
typedef Iterator iterator;
typedef Iterator const_iterator; //BOOST_FOREACH appears to want this
iter_pair(iterator first, iterator last): first(first), last(last) {}
iterator begin() const { return first; }
iterator end() const { return last; }
private:
iterator first, last;
};
template <class Container>
struct iterator_type
{
typedef typename Container::iterator type;
};
template <class Container>
struct iterator_type<const Container>
{
typedef typename Container::const_iterator type;
};
template <class Container>
iter_pair<typename iterator_type<Container>::type>
slice(Container& c, size_t i_first, size_t i_last)
{
typedef typename iterator_type<Container>::type iterator;
iterator first = c.begin();
std::advance(first, i_first);
iterator last = first;
std::advance(last, i_last - i_first);
return iter_pair<iterator>(first, last);
}
template <class Container>
iter_pair<typename iterator_type<Container>::type>
slice(Container& c, size_t i_last)
{
return slice(c, 0, i_last);
}
//could probably also be overloaded for arrays
#include <cctype>
#include <string>
#include <boost/foreach.hpp>
#include <iostream>
int main()
{
std::string s("Hello world, la-la-la!");
BOOST_FOREACH(char& c, slice(s, 2, 11)) {
if (c == 'l')
c = std::toupper(c);
}
const std::string& r = s;
BOOST_FOREACH(char c, slice(r, r.size() - 1)) {
std::cout << c << " ";
}
std::cout << '\n';
}
En général, on serait probablement travailler avec itérateurs en premier lieu, il pourrait ne pas être très utile.
Il serait sans doute plus facile de le faire 'std :: for_each (de, à , [] (int k) {processNumber (k);}); '. Ou vous devrez fournir un pour chaque sous-gamme compatible dans ce vecteur. –
Oui, j'en suis conscient. Je veux juste connaître les limites de la boucle for-range en C++ par rapport à d'autres langages où le découpage est "facile". – Klaim
La solution 'for_each' présentée ci-dessus n'est-elle pas" facile "? – jalf