读书笔记中涉及到的所有代码实例可通过https://github.com/LuanZheng/EffectiveCPlusPlus.git进行下载获得。
0 导读
将构造函数声明为explicit,可组织它们被用来执行隐式类型转换。常常更受欢迎,因为它们禁止编译器执行非预期的类型转换。
#ifndef _A_H_
#define _A_H_
class A
{
public:
A(int a);
//explicit A(int a); 如果声明为explicit,则编译时会报错,不允许隐式类型转换
private:
int m_a;
};
#endif
#include "A.h"
#include <iostream>
A::A(int a)
{
std::cout << "Default construction function A called." << std::endl;
m_a = a;
std::cout << m_a << std::endl;
}
#include "A.h"
void doSometing(A a);
int main()
{
A a(3);
doSometing(a);
doSometing(4); //auto implicit type conversions called!
return 0;
}
void doSometing(A a)
{
}
“=”语法有时是拷贝赋值,有时是拷贝构造。在这种情形下,拷贝构造和拷贝赋值的区别为:如果一个新对象被定义,一定会有个构造函数被调用,不可能调用赋值操作。例如:
Widget w3=w2; //调用拷贝构造函数
而如果没有新对象被定义,则调用拷贝赋值。例如:
Widget w1;
Widget w2;
w2 = w1;
Pass-by-Value意味着调用拷贝构造函数,以by-value方式传递用户自定义类型通常是个坏主意,Pass-by-reference-to-const往往是个比较好的选择;详见条款20.
例子见Introduction