no lo hace, pero se puede simular con una macro.
template<typename T>
struct false_wrapper
{
false_wrapper(const T& value) : value(value) { }
operator bool() const { return false; }
T value;
};
template<typename T>
false_wrapper<T> make_false_wrapper(const T& value)
{
return false_wrapper<T>(value);
}
template<typename T>
struct false_ref_wrapper
{
false_ref_wrapper(T& value) : value(value) { }
operator bool() const { return false; }
T& value;
private:
false_ref_wrapper& operator=(const false_ref_wrapper&);
};
template<typename T>
false_ref_wrapper<T> make_false_ref_wrapper(T& value)
{
return false_ref_wrapper<T>(value);
}
template<typename T>
void increment(T& it)
{
++it;
}
#define foreach_(VAL, VALS) \
if (auto _foreach_col = make_false_ref_wrapper(VALS)) { } else \
if (auto _foreach_cur = make_false_wrapper(std::begin(_foreach_col.value))) { } else \
if (auto _foreach_end = make_false_wrapper(std::end(_foreach_col.value))) { } else \
for (bool _foreach_flag = true; \
_foreach_flag && _foreach_cur.value != _foreach_end.value; \
_foreach_flag ? increment(_foreach_cur.value) : (void) 0) \
if ((_foreach_flag = false) == true) { } else \
for (VAL = *_foreach_cur.value; !_foreach_flag; _foreach_flag = true)
MSVC10 implementó una propuesta anterior, algo como 'para cada uno (int & p en la matriz)' debe trabajar –
Parece que esta es la documentación de lo @BenVoigt menciona: [Cómo iterar sobre la colección STL por cada ] (http://msdn.microsoft.com/en-us/library/ms177203.aspx). Parece que originalmente se diseñó para código C++/CLR, y también parece que podría no funcionar con matrices que no sean CLR. – crashmstr
Supongo que esto para cada uno (T & t in tt) solo funcionará en el compilador VS2010? – paulm