C++中的explicit

xiaoxiao2021-02-28  76

C++中, 一个参数的 构造函数(或者除了第一个参数外其余参数都有默认值的多参构造函数), 承担了两个角色。 1 是个 构造器 ,2 是个默认且隐含的类型转换操作符。 所以, 有时候在我们写下如 AAA = XXX, 这样的代码, 且恰好XXX的类型正好是AAA单参数构造器的参数类型, 这时候 编译器就自动调用这个构造器, 创建一个AAA的对象。

这样看起来好象很酷, 很方便。 但在某些情况下(见下面权威的例子), 却违背了我们(程序员)的本意。 这时候就要在这个构造器前面加上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构造函数只能被显式调用。

转载请注明原文地址: https://www.6miu.com/read-94894.html

最新回复(0)