c++ - 如何强制复制省略,为什么它不能与删除的复制构造函数一起使用?

标签 c++ c++11 copy-elision

我有一个不可复制的类。复制这个会有问题。我想保证它永远不会被复制,所以我将它的复制构造函数删除:

class A {
  public:
    A();
    A(const A&) = delete;
};

A fun() {
  return A();
};

int main() {
  A a = fun();
};

不幸的是,g++ 不会编译它的原因是:

t.cc: In function ‘A fun()’:
t.cc:8:12: error: use of deleted function ‘A::A(const A&)’
   return A();
            ^
t.cc:4:5: note: declared here
     A(const A&) = delete;
     ^
t.cc: In function ‘int main()’:
t.cc:12:13: error: use of deleted function ‘A::A(const A&)’
   A a = fun();
             ^
t.cc:4:5: note: declared here
     A(const A&) = delete;
     ^

但这是一个非常明确的情况,应该使用复制省略,所以永远不应该调用复制构造函数。为什么会这样?

最佳答案

在 C++17 之前,复制省略是编译器不需要执行的优化,因此类必须是可复制的,因为编译器可能想要复制(即使它实际上不需要)。在 C++17 中,在许多情况下将保证复制省略,然后类将不需要复制构造器。

另见:

http://en.cppreference.com/w/cpp/language/copy_elision

http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/p0135r0.html

https://herbsutter.com/2016/06/30/trip-report-summer-iso-c-standards-meeting-oulu/ (关于“保证复制省略”的内容)

您也许可以使用在您的类中声明复制构造函数但不实际实现它的老把戏?只要编译器实际上不调用复制构造函数,那应该会让编译器满意。我没有对此进行测试,但我相信在 C++17 到来之前它应该适用于您的情况。

关于c++ - 如何强制复制省略,为什么它不能与删除的复制构造函数一起使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49893051/

相关文章:

c++ - 设置对话框窗口的边框颜色

c++ - 我的 c++ 项目在 vc++ 2008 中工作,但在 vc++ 2010 中不工作

c++ - 从 vector 类的 vector 中读取数据 - C++

c++ - C++ 模板中的函数签名

c++ - 查找迭代器的值类型

c++ - 为什么不使用 `make_x()` 函数尽可能省略 move 构造函数?

c++ - std::vector元素的初始化 move/复制构造函数

c++ - vector.push_back 右值和复制省略

c++ - C++20 的奇怪返回值需要表达式

C++ Lambdas 和 Variadic 模板包装器