考虑如下定义的类:
class C {
public:
C(std::vector<std::string>) {}; // (1)
C(std::map<std::string, std::string>) {}; // (2)
};
然后使用列表初始化器创建它的两个实例,如下所示:
C A({ "A", "B" });
C B({ { "A", "B" }, { "C", "D" } });
我期望object A
通过(2)
使用(1)
构造函数和object B
。但事实并非如此,我得到了以下输出:error: call to constructor of 'C' is ambiguous
。
此外,如果我尝试像这样声明这些实例:
C A = { "A", "B" };
C B = { { "A", "B" }, { "C", "D" } };
相反,它会失败,并显示以下内容:error: no matching constructor for initialization of 'C'
。
怎么一回事?
我如何才能达到预期的行为?( A -> (1)
,B -> (2)
)也许是以某种方式使用SFINAE?
发布于 2019-04-08 05:32:22
我已经通过以下方式实现了你想要的东西:
class C {
public:
C(std::vector<std::string>) { std::cout << "here1" << std::endl; } // (1)
C(std::map<std::string, std::string>) { std::cout << "here2" << std::endl; } // (2)
};
int main()
{
C A = C( { {"A"}, {"B"} });
C B = C( std::map<std::string, std::string> { {"A", "B"}, {"C", "D"} } );
// or C B = C( { std::make_pair("A", "B"), std::make_pair("C", "D") } );
}
编辑(使用统一初始化)
https://stackoverflow.com/questions/55563730
复制相似问题