鉴于以下情况:
#include <stdio.h>
class X;
class Y
{
public:
Y() { printf(" 1\n"); } // 1
// operator X(); // 2
};
class X
{
public:
X(int) {}
X(const Y& rhs) { printf(" 3\n"); } // 3
X(Y&& rhs) { printf(" 4\n"); } // 4
};
// Y::operator X() { printf(" operator X() - 2\n"); return X{2}; }
int main()
{
Y y{}; // Calls (1)
printf("j\n");
X j{y}; // Calls (3)
printf("k\n");
X k = {y}; // Calls (3)
printf("m\n");
X m = y; // Calls (3)
printf("n\n");
X n(y); // Calls (3)
return 0;
}
到目前为止,一切都很好。现在,如果我启用转换运算符Y::operator X()
,我会得到这个;-
X m = y; // Calls (2)
我的理解是,发生这种情况是因为(2)比(3)“更少”,因此是首选。X
省略了对构造函数的调用
我的问题是,为什么定义没有X k = {y}
以同样的方式改变它的行为?我知道这= {}
在技术上是“列表复制初始化”,但是在没有构造函数采用initializer_list
类型的情况下,这不会恢复为“复制初始化”行为吗?ie - 与 for 相同X m = y
我的理解的漏洞在哪里?