隐式类型转换 (构造函数的隐式调用)
举例:

#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. 我激励你遵循雷同的政策.