c++ 隐式类型转换

本文深入探讨了C++中的隐式类型转换,解释了其工作原理和必要性,列举了常见转换示例,包括基本数据类型和类之间的转换,并讨论了其潜在风险。同时,介绍了如何使用explicit关键字来控制隐式转换。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

谈谈c++隐式类型转换

  • 什么是c++隐式类型转换?这是指c++自动将一种类型转换成另一种类型,是编译器的一种自主行为。
  • 为什么c++需要隐式类型转换?
    1. c++多态的特性,就是通过父类的对象实现对子类的封装,以父类的类型返回之类对象。
    2. c++中使用父类的地方一定可以使用子类代替,这也得益于隐式类型转换。
    3. c++是一种强类型的语言,有着非常严格的类型检查,采用隐式类型转换会使程序员更方便快捷一点。
    4. 但是在享受方便的时候,风险也紧跟其后。

列举一些隐式类型转换的例子

int i=3;
double j = 3.1;
i+j;//i会被转换成double类型,然后才做加法运算。
class A{};
class B: public A
{};//B是子类
void Fun(A& a);
B b;
Fun(b);//使用子类对象代替父类对象是可以的,也是因为隐式类型转换。

有时候隐式类型转换并不好

class Test
{
	public:
		Test(int i);
};

Test t1 = 1;//正确,由于强制类型转换,1先被Test构造函数构造成Test对象,然后才被赋值给t1
Test t2(1);//正确
  1. 这种情况有时候很好,如果程序员的本意就是如此,那可以省去好几行代码。
  2. 有时这种情况看起来就不那么好,可能是一个错误,程序员错误的写出了这行代码,但是它却奇迹般的没有导致错误,要是因此产生一个bug,那么将是灾难性的。
  3. 为了更准确的表达程序员的自我意愿,本着不怕多写几行代码的心,就使用c++ explicit关键词
  • 再比如有函数用到Test类
void fun(Test& t);
fun(1);//这样调用是没有问题的,隐式类型转换会把1转换成Test的对象。

explic关键词的用法

class Test
{
	public:
		explicit Test(int i);
};
Test t2 = 1;//编译报错
Test t2(2);//编译没问题

总结

  • 隐式类型转换,是编译器自发的行为,所以安全是第一位。所以呢,我们可以得出一条很重要的结论:
    1. 隐式类型转换是从小到大的转换。在数据类型上表现是少字节数据类型,转换成多字节数据类型,保证数据的完整性;在类上表现,从子类转换成父类,保证类对象功能的正常。
    2. 隐式类型转换往往是安全的,但是它可能产生意想不到的危险。
  • 既然有隐式类型转换,那么肯定就有强制类型转换。既然是强制的,那么我们可以猜测一下几点:
    1. 强制类型转换,往往是不安全的,这点要使用者去把握,去了解这种使用是不是安全。
      2. 强制类型转换又是强大的,只要你能保证做的转换的正确性,那么它就是好用的。
  • 强制类型转换和隐式类型转换,我们不能片面的看待他们是不是安全的。存在即合理,安不安全还是要看程序员自己在使用上是否正确,是否合理。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值