C 中的复制构造函数优化
C 中,在特定情况下,复制构造函数可能不会被调用,提示有关编译器优化或该语言未记录的功能。
考虑以下内容code:
class A { public: A(int value) : value_(value) { cout << "Regular constructor" << endl; } A(const A& other) : value_(other.value_) { cout << "Copy constructor" << endl; } private: int value_; }; int main() { A a = A(5); }
人们会期望输出包含“常规构造函数”和“复制构造函数”消息。但是,在这种情况下,永远不会调用复制构造函数。
此行为既不是编译器优化,也不是 C 的未记录功能。相反,C 标准 (§12.8.15) 中明确指定了 T = x; 等赋值语句。可以解释为 T(x);,在不需要复制时有效地消除内部 T。
在这种特殊情况下,编译器认识到构造 A 对象然后复制它是多余的因此省略了复制构造函数的调用。
要强制执行复制构造函数的调用,可以显式创建第一个 A 对象:
A a; // Construct an empty A object a = A(5); // Copy-initialize it with another A object
以上是C何时跳过复制构造函数?的详细内容。更多信息请关注PHP中文网其他相关文章!