【发布时间】:2018-04-14 18:42:46
【问题描述】:
我一直在使用一组模板函数contains
代码如下:
template<class V>
bool contains(const std::unordered_set<V>& c, const V& e)
{
return c.find(e) != c.cend();
}
我也有 std::set、std::map 和 std::unordered_map 的类似版本
但是,我最近在使用它时遇到了链接错误:
CMakeFiles/dietAgent.dir/agent/workflow/autoscale/AutoscaleCoreScheduler
.cc.o : Dans la fonction « bool contains<WfNode*, WfNode*>
(std::unordered_set<WfNode*, std::hash<WfNode*>, std::equal_to<WfNode*>,
std::allocator<WfNode*> > const&, WfNode* const&) » :
/home/amxx/Work/Thesis/Code/diet/src/utils/stdext.hh:51 : référence
indéfinie vers « std::integral_constant<bool, true> operator!=
<std::__detail::_Node_const_iterator<WfNode*, true, false>,
std::__detail::_Node_const_iterator<WfNode*, true, false> >
(std::__detail::_Node_const_iterator<WfNode*, true, false> const&,
std::__detail::_Node_const_iterator<WfNode*, true, false> const&) »
我从错误中了解到的是迭代器没有 operator!= ... WTF 吗?
更新:
显然,模板化包装器不应该受到责备。我尝试使用
if (mySet.find(value) != mySet.end()) { ... }
直接(而不是调用contains),我得到了相同的undefined referennce to operator!=
【问题讨论】:
-
@wally,我试过但没有成功...可能是因为问题出在链接上...
-
WfNode对象是否随时间变化,或者它们是不可变的?如果地址是集合中的“值”,则可能无关紧要。 -
WfNode不是 const,它们包含非常量方法,但指针不应该受到影响 -
将
cend更改为end将比较std::__detail::_Node_const_iterator和std::__detail::_Node_iterator,这并不能解决任何问题并增加了不必要的差异