出于某种原因,在迭代两个 vector 时,迭代器的执行速度比 BOOST FOREACH 快得多...我正在使用启用了优化的 visual studio 2012。下面是我比较的两段代码......我错过了什么吗?
typedef boost::tuple<int&, int&> int_ref_tuple;
BOOST_FOREACH(int_ref_tuple tup, boost::combine(v1, v2))
tup.get<0>() = tup.get<1>();
对比
vector<int>::iterator iIter = v1.begin();
vector<int>::const_iterator jIter = v2.begin();
for (;iIter != v1.end();++iIter, ++jIter)
{
//this is faster
}
最佳答案
尝试:
BOOST_FOREACH(int_ref_tuple &tup, boost::combine(v1, v2))
关于c++ - 迭代两个 vector 迭代器比 boost_foreach 更快,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13617860/