深入理解C++11 读书笔记(三) 通用与专用

本文深入探讨C++11的新特性,包括继承构造函数的使用,如何通过委派构造函数减少重复代码,以及移动语义和完美转发的概念。移动语义利用右值引用优化资源转移,完美转发则解决了函数模板参数传递的问题。此外,还介绍了显示转换操作符、初始化列表和POD类型的定义与优势。
摘要由CSDN通过智能技术生成

继承构造函数

  • 如果派生类并不需要改变构造函数,那么可以用新的using Base::Base直接继承基类的构造函数,基类构造函数很多的时候,这样做非常方便。如果派生类还有自己的成员需要初始化,可以利用类成员初始化表达。
class A{
   
    A(int a):a(a){}
    int a;
};

class B:A
{
   
    using A::A
}
  • 使用继承构造函数,编译器不会产生真正的目标代码,可以节约目标代码控件。
  • 继承构造函数参数的默认值不会被继承,而且会产生多个继承构造函数。A(int a = 1,double = 2)的继承类使用using A::A会产生B(int,double);B(int);B();B(const B &);多个构造函数。因此,如果父类有默认参数的构造函数,使用继承构造需要很小心。

委派构造函数

  • 在自己的构造函数里调用自己另外的构造函数,以便减少重复代码。
class A{
    A(){init();}
    A(int a):{init();this->a = a;}
    A(char c):{init();this->c = c;}
};
  • 使用tricky一点的方法是利用placement new
class A{
   
    A(){init();}
    A(int a):{ new(this)A();this->a = a;}
    A(char c):{
  new(this)A();this->c = c;}
};
  • 在C++11中使用委派构造函数
class A{
    A(){init();}
    A(int a):A(){ this->a = a;}
    A(char c):A(){this->c = c;}
};
  • 区别调用者和被调用者,A(int a)被称为 委派构造函数(delegate constructor),A()被称为 目标构造函数(target constructor)。
  • 委派构造函数和初始化列表不能同时使用。比如A(int):A(),a(a){}是非法的,初始化代码需要放到函数体。
  • 委派构造函数互相调用会形成链状,但是不能成环,会导致编译错误。

移动语义和完美转发

  • 移动语义:利用右值临时变量对变量进行拷贝构造时,变量偷走有时右值变量构造函数里创建的堆上的资源。右值临时变量是即将消失的变量,拿走堆上的资源不会产生问题,减少堆的拷贝。
class A{
    A(){ d = new Data;}
    A(const A & a):d(new Data(a.d)){}//普通拷贝
    A(A && a):d(a.d)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值