我正在尝试使用我定义的自定义Node
类型来实例化boost::mutable_queue的简单版本。使用以下代码段(使用std和boost名称空间以及所有必需的包含)实例化mutable_queue<double>
实例时,我没有遇到任何问题:
int N = 100;
mutable_queue<double> *q =
new mutable_queue<double>(N, less<double>(), identity_property_map());
但是,当我尝试将double
切换为Node
时(我已经超载operator<
和operator==
),我无法再获取它工作。这是我正在尝试的一个代表性例子:
typedef Node entry_t;
typedef vector<entry_t> storage_t;
typedef less<entry_t> comp_t;
typedef identity_property_map prop_map_t;
//typedef iterator_property_map<storage_t,
// property_map<storage_t, entry_t>::type > prop_map_t;
typedef mutable_queue<entry_t, storage_t, comp_t, prop_map_t> queue_t;
queue_t *q = new queue_t(N, comp_t(), prop_map_t());
这给了我这些错误:
error: no matching function for call to ‘boost::mutable_queue >, std::less, boost::identity_property_map>::push(Node*&)’ mutable_queue.h:100: note: candidates are: void boost::mutable_queue::push(const IndexedType&) [with IndexedType = UnitTest::Node_test()::entry_t, RandomAccessContainer = std::vector >, Comp = std::less, ID = boost::identity_property_map]
我怀疑我不理解如何使用property_map
。有人可以帮我解决这个片段,也许可以解释为什么这是正确的做法?
答案 0 :(得分:1)
我没有看到你在哪里调用push,但是当你应该推送一个Node时,你似乎正在推动Node *:
::push(Node*&)
它告诉你推动Node const&amp;:
push(const IndexedType&)
其中IndexedType = Node