可能我的理解explicit
不够,但是我想知道为什么在下面的代码中,当我将通用引用构造函数声明为explicit
.
struct A
{
A() = default;
template<typename T>
A(T&& t) { std::cout<<"hides copy constructor"<<std::endl; }
};
struct A_explicit
{
A_explicit() = default;
template<typename T>
explicit A_explicit(T&& t) { std::cout<<"does not hide copy constructor?"<<std::endl; }
};
int main()
{
A a;
auto b = a; (void) b; //prints "hides copy constructor"
A_explicit a_exp;
auto b_exp = a_exp; (void) b_exp; //prints nothing
}
这是一种通用的解决方案,而不是 SFINAE 的东西,否则将适用于防止隐藏A
(例如,通过std::enable_if_t<!std::is_same<std::decay_t<T>, A>::value>
,请参见此处)?