带有右值引用的C构造函数

带有右值引用的C构造函数,第1张

概述考虑这个有三个构造函数的类: class Circle {public: Circle(int r) { _radius = r; }Circle(const Circle& c){ _radius = c.radius(); cout << endl << "Copy constructor with lvalue reference. Radius: " 考虑这个有三个构造函数的类:

class Circle {public: Circle(int r) {      _radius = r; }Circle(const Circle& c){    _radius = c.radius();    cout << endl << "copy constructor with lvalue reference. Radius: " << _radius;}Circle(Circle&& c){    _radius = c.radius();    cout << endl << "copy constructor with rvalue reference. Radius:" << _radius;}int radius() const {    return _radius;}private:    int _radius;};int main() {     Circle c1(2);     Circle c2(c1);     cout << endl << c2.radius();      Circle c3(Circle(4));     cout << endl << c3.radius();      return 0; }

用“g -std = c 0x”编译.输出是:

copy constructor with lvalue reference. Radius: 224

好.调用前两种情况的正确构造函数.但对于
第三种情况,即Circle c3(Circle(4)),我期待第三种构造函数,
(要用rvalue referecne复制构造函数)要调用,但事实并非如此.
显然有一些构造函数被调用,因为c3被正确实例化了但是我
不明白为什么编译器没有使用显式提供的
一.我在这里错过了什么吗?

解决方法 为了获取rvalue引用,它应该是非const的,因为构造函数参数的内容将被移动,并且通常这是一个更改 *** 作数状态的 *** 作(尽管不是在您的特定情况下):

Circle(Circle&& c){ }

此外,您在这里看到了一个副本省略:

Circle c3(Circle(4));

所以不会调用move构造函数.这是可能会或可能不会发生的标准编译器优化.如果你要像这样构建一个Circle:

Circle c3(std::move(c1));

然后你会调用移动构造函数.

总结

以上是内存溢出为你收集整理的带有右值引用的C构造函数全部内容,希望文章能够帮你解决带有右值引用的C构造函数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1219577.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存