首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在C++11中按值返回构造对象时避免复制构造函数调用

在C++11中按值返回构造对象时避免复制构造函数调用
EN

Stack Overflow用户
提问于 2019-02-01 09:09:53
回答 2查看 105关注 0票数 3

我有一个没有复制构造函数的类,我仍然想按值返回它。下面的MCVE在C++17中编译:

代码语言:javascript
复制
class Cls {
    public:
    Cls(int x) {}
    Cls(const Cls& c) = delete;
};

Cls f(int x) {
    return Cls(x);
}

int main() {
    f(0);
}

但在C++11中并非如此:

代码语言:javascript
复制
$ g++ prog.cc -Wall -Wextra -std=c++11
prog.cc: In function 'Cls f(int)':
prog.cc:9:17: error: use of deleted function 'Cls::Cls(const Cls&)'
    9 |     return Cls(x);
      |                 ^
prog.cc:5:5: note: declared here
    5 |     Cls(const Cls& c) = delete;
      |     ^~~

据我所知,原因是编译器不允许优化复制,即使在这种情况下它应该是微不足道的。

我希望return std::move(Cls(x));能够工作,并避免复制构造函数,但它也会产生同样的错误。

我可以在不定义复制构造函数(或辅助操作符)的情况下修复这个问题吗?

我看过相关的问题,但找不到副本。

EN

回答 2

Stack Overflow用户

发布于 2019-02-01 09:13:11

而是实现一个移动构造函数。

在C++17中,编译器必须执行复制省略,而不必复制或移动对象。但是对于C++11来说,你没有这个设施,但你可以移动你的案件:

代码语言:javascript
复制
Cls(Cls&& c) = default;
票数 3
EN

Stack Overflow用户

发布于 2019-02-01 10:08:49

我可以在不定义复制构造函数(或辅助操作符)的情况下修复这个问题吗?

在您的案例中有两种选择:

  • 定义移动构造函数: Cls(Cls& c) =违约;
  • 使用复制列表初始化,它允许不调用复制/移动构造函数,它需要一个非显式构造函数: Cls f(int x) {返回{x};} 演示

在C++17中,您有“保证”复制(或“非物化值传递”),因此return Cls(x);是可以的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54476215

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档