2

我正在尝试将项目从 VS2008 转换为 2010,但由于添加了移动构造函数(并且可能是这里有嵌套的 list_of 的事实)而遇到了问题。以下代码片段显示了错误(在实际代码中,这些构造用于初始化一些静态):

enum some_enum {R, G, B};

typedef std::pair<some_enum, some_enum> Enum_Pair;
typedef std::vector<some_enum> Enum_list;
typedef std::pair<Enum_Pair, Enum_list> Some_Struct;
typedef std::list<Some_Struct> Full_Struct;

#define MAKEFULLSTRUCT(First_, Second_, some_enums)\
    (Some_Struct(Enum_Pair(First_, Second_), list_of (some_enums) ))

int main()
{
    int i = G;
    Full_Struct test_struct = list_of
        MAKEFULLSTRUCT(R, R, R).to_container(test_struct);
}

这导致

error C2668: 'std::vector<_Ty>::vector' : ambiguous call to overloaded function
with  [_Ty=some_enum]
vector(593): could be 'std::vector<_Ty>::vector(std::vector<_Ty> &&)'
with  [ _Ty=some_enum]
vector(515): or       'std::vector<_Ty>::vector(unsigned int)'
with  [ _Ty=some_enum]
while trying to match the argument list '(boost::assign_detail::generic_list<T>)'
with  [ T=some_enum ]

有没有办法在仍然使用 boost::list_of 的同时解决这个问题?还是我必须切换到另一种初始化机制?

4

1 回答 1

7

这看起来像 Boost.Assign 中的一个错误。的返回类型list_of具有到类型的通用转换,而根本T没有尝试约束T。因此,任何一个std::vector构造函数——一个接受 astd::vector &&的一个和一个接受 a 的unsigned int——都同样好,从而导致歧义。

您的解决方法是使用convert_to_container,如下所示:

#define MAKEFULLSTRUCT(First_, Second_, some_enums)\
    (Some_Struct(Enum_Pair(First_, Second_), \
        list_of(some_enums).convert_to_container<Enum_list>()))
于 2012-09-11T03:57:14.813 回答