https://www.jb51.cc/csharp/1192655.html

编程之家收集整理的这篇文章主要介绍了C++隐式类型转换是什么?编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

C++中隐式类型转换是指:从“构造函数形参类型”到“该类类型”的一个编译器的自动转换。隐式类类型转换是会带来风险的,隐式转换得到类的临时变量,完成操作后就消失了,我们构造了一个完成测试后被丢弃的对象。

https://s3-us-west-2.amazonaws.com/secure.notion-static.com/95265e9c-10c4-441d-b979-2a012bf412f1/6a4199ef5dac94bea716efaf82d29a4c.jpg

C++ 隐式类类型转换

《C++ Primer》中提到:

“可以用 单个形参来调用 的构造函数定义了从 形参类型 到 该类类型 的一个隐式转换。”

这里应该注意的是, “可以用单个形参进行调用” 并不是指构造函数只能有一个形参,而是它可以有多个形参,但那些形参都是有认实参的。

那么,什么是“隐式转换”呢? 上面这句话也说了,是从 构造函数形参类型 到 该类类型 的一个编译器的自动转换。

下面通过代码来看一看:

    cout<<A.isSameISBN(string("A-A-A"))<<endl; //此处即发生一个隐式转换:string类型-->BOOK类型,借助BOOK的构造函数进行转换,以满足isSameISBN函数的参数期待。

代码中可以看到,isSameISBN函数是期待一个BOOK类类型形参的,但我们却传递了一个string类型的给它,这不是它想要的啊!还好,BOOK类中有个构造函数,它使用一个string类型实参进行调用,编译器调用了这个构造函数,隐式地将stirng类型转换为BOOK类型(构造了一个BOOK临时对象),再传递给isSameISBN函数

隐式类类型转换还是会带来风险的,正如上面标记,隐式转换得到类的临时变量,完成操作后就消失了,我们构造了一个完成测试后被丢弃的对象。

我们可以通过explicit声明来抑制这种转换:

explicit关键字只能用于类内部的构造函数声明上.这样一来,BOOK类构造函数就不能用于隐式地创造对象了,编译上面的代码会出现这样的提示

https://s3-us-west-2.amazonaws.com/secure.notion-static.com/e9114181-c107-4512-a83d-eb93ad7a11d1/4290d86ff9bf43d4ddb779344f810b54.png

现在用户只能进行显示类型转换,显式地创建临时对象。

总结一下: