隐式类型转换 (构造函数的隐式调用)
举例:
#include <iostream>using namespace std;class Point {public: int x, y; Point(int x) : x(x) {}};void displayPoint(const Point& p) { cout << "(" << p.x << ")" << endl;}int main(){ displayPoint(1); Point p = 1;}
explicit关键字
指定构造函数或转换函数 (C++11起)为显式, 即它不能用于隐式转换和复制初始化.
构造函数被explicit润饰后, 就不能再被隐式调用了. 也就是说, 之前的代码, 在Point(int x)前加了explicit润饰, 就无奈通过编译了.
//退出explicit关键字后#include <iostream>using namespace std;class Point {public: int x, y; explicit Point(int x) : x(x) {}};void displayPoint(const Point& p) { cout << "(" << p.x << ")" << endl;}int main(){ displayPoint(1); Point p = 1;}
Effective C++:
被申明为explicit的构造函数通常比其 non-explicit 兄弟更受欢迎, 因为它们禁止编译器执行非预期 (往往也不被冀望) 的类型转换. 除非我有一个好理由容许构造函数被用于隐式类型转换, 否则我会把它申明为explicit. 我激励你遵循雷同的政策.