我大量使用 BOOST_FOREACH
来迭代容器,并且由于我最近转向 c++0x,我认为我可以用基于范围的 替换
构造。下面这段代码BOOST_FOREACH
>for
#include<vector>
#include<boost/shared_ptr.hpp>
#include<boost/range.hpp>
using std::vector; using boost::shared_ptr;
class Node;
int main(void){
vector<shared_ptr<Node>> nodes;
for(const shared_ptr<Node>& n: nodes);
}
无法使用gcc
4.6进行编译,导致
error: call of overloaded 'end(std::vector<boost::shared_ptr<Node> >&)' is ambiguous
note: candidates are:
/usr/include/c++/4.6/bits/range_access.h:78:5: note: decltype (__cont->end()) std::end(const _Container&) [with _Container = std::vector<boost::shared_ptr<Node> >, decltype (__cont->end()) = __gnu_cxx::__normal_iterator<const boost::shared_ptr<Node>*, std::vector<boost::shared_ptr<Node> > >]
/usr/include/c++/4.6/bits/range_access.h:68:5: note: decltype (__cont->end()) std::end(_Container&) [with _Container = std::vector<boost::shared_ptr<Node> >, decltype (__cont->end()) = __gnu_cxx::__normal_iterator<boost::shared_ptr<Node>*, std::vector<boost::shared_ptr<Node> > >]
/usr/include/boost/range/end.hpp:103:47: note: typename boost::range_iterator<const T>::type boost::end(const T&) [with T = std::vector<boost::shared_ptr<Node> >, typename boost::range_iterator<const T>::type = __gnu_cxx::__normal_iterator<const boost::shared_ptr<Node>*, std::vector<boost::shared_ptr<Node> > >]
/usr/include/boost/range/end.hpp:92:41: note: typename boost::range_iterator<C>::type boost::end(T&) [with T = std::vector<boost::shared_ptr<Node> >, typename boost::range_iterator<C>::type = __gnu_cxx::__normal_iterator<boost::shared_ptr<Node>*, std::vector<boost::shared_ptr<Node> > >]
有没有办法避免这种歧义,或者基于范围的方法在这种情况下根本无法使用?
最佳答案
棘手。你正在拉进来std::end
和boost::end
因为 std::vector<boost::shared_ptr>
的关联命名空间都是std
和boost
。两者都是匹配的模板。
但是,非模板end()
将是一个更好的匹配。因此,只需提供您自己的:
inline std::vector<boost::shared_ptr<Node> >::iterator
end(std::vector<boost::shared_ptr<Node> > vsn&)
{
return std::end(vsn);
}
关于STL - 基于 STL 容器的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6871271/