因此,我有一个 boost 多索引容器。
using namespace boost::multi_index;
template < typename O >
class Container
{
public:
multi_index_container<
O,
indexed_by<
ordered_unique<
const_mem_fun< O, std::string, &O::name >
>
>
> _container;
};
正如你所看到的,通过这种设计,我用来创建这个容器的每个对象都必须有一个成员函数,返回一个名为“name”的字符串。
这显然不理想。我尝试了几种传递“密钥”的方法,但我无法让它们中的任何一个工作..
我试过这个..
using namespace boost::multi_index;
template < typename O, typename KT, typename KM >
class Container
{
public:
multi_index_container<
O,
indexed_by<
ordered_unique<
const_mem_fun< O, KT, &KM >
>
>
> _container;
};
int main( int c, char *v[] )
{
Container< Object, std::string, Object::name > container;
}
但没有快乐..
编译器抱怨 Object::name 不是类型,但我不知道如何纠正这个问题。即使我知道如何为模板提供类型,我仍然需要容器使用“Object::name”的具体实例。
也许我必须在构造时先提交类型,然后再提交成员函数?但是我该如何构建容器..我的头疼!?!
下面的 Alexy 好心地提供了这个解决方案
using namespace boost::multi_index;
template < typename O, typename KT, KT (O::* KM)() >
class Container
{
public:
multi_index_container<
O,
indexed_by<
ordered_unique<
const_mem_fun< O, KT, KM >
>
>
> _container;
};
int main( int c, char *v[] )
{
Container< Object, std::string, &Object::name > container; // <<---- ERROR HERE
}
但是,这产生了以下编译器错误。
Template parameter KM requires an expression of type std::string (Object::*)().
在标记的行..
行。事实证明这是我的错,因为我提交了一个签名不正确的“&Object::name”参数……我已经解决了这个问题……