C++提供了explicit,可以阻止不应该允许的经过进行的隐式转换的发生。声明为explicit的不能在隐式转换中使用。
C++中, 一个参数的 (或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个 ,2 是个默认且隐含的类型转换操作符。
所以, 有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候 就自动调用这个构造器, 创建一个AAA的对象。
这样看起来好象很酷, 很方便。 但在某些情况下(见下面权威的例子), 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上explicit修饰, 指定这个构造器只能被明确的调用/使用, 不能作为类型转换操作符被隐含的使用。
explicit 的作用
解析:
explicit构造函数是用来防止隐式转换的。请看下面的代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | class Test1 { public : Test1( int n) { num=n; } //普通构造函数 private : int num; }; class Test2 { public : explicit Test2( int n) { num=n; } //explicit(显式)构造函数 private : int num; }; int main() { Test1 t1=12; //隐式调用其构造函数,成功 Test2 t2=12; //编译错误,不能隐式调用其构造函数 Test2 t2(12); //显式调用成功 return 0; } |
Test1的 带一个int型的参数,代码23行会隐式转换成调用Test1的这个构造函数。而Test2的构造函数被声明为explicit(显式),这表示不能通过隐式转换来调用这个构造函数,因此代码24行会出现编译错误。
普通构造函数能够被 。而explicit构造函数只能被显式调用。