C++--类型转换详解(隐式类型转换、强制类型转换)

本文详细介绍了C++中的类型转换,包括隐式类型转换(内置数据类型和自定义数据类型)和强制类型转换(static_cast、reinterpret_cast、const_cast和dynamic_cast),强调了各种转换的操作场景、注意事项和潜在风险。通过实例解析了不同类型转换的应用,并提醒了在面试中可能遇到的相关问题。
摘要由CSDN通过智能技术生成

C++类型转换

C++类型转换主要分为两种:隐式类型转换和显式类型转换(强制类型转换)。

(type)expression //C风格转换格式
static_cast<type>(expression) //C++风格转换格式
1. 隐式类型转换

所谓隐式类型转换,是指不需要用户干预,编译器默认进行的类型转换行为(很多时候用户可能都不知道到底进行了哪些转换)。

隐式类型转换一般分为两种:内置数据类型、自定义数据类型。

1.1 内置数据类型

C++的隐式类型转换,都满足一个基本原则:由低精度向高精度的转换。若不满足该原则,编译器会提示编译警告

举例说明:
例1:混合类型的算术运算表达式中

int int_value = 8;
double dou_value = 10.7;
double dou_Sum = int_value + dou_value; // int_value会被自动转换为double类型,用转换的结果再与dou_value相加.

例2:不同类型的赋值操作时

int value = true; // bool类型被转换为int类型

例3:函数参数传值时

void func(double dArg); // 声明函数
func(1); // 调用函数。整型数值1被默认转换为double类型数值1.0

例4:函数返回值时

double add(int num1, int num2)
{
   
   return (num1 + num2); // 运算结果会被隐式转换为double类型返回
}

若不满足该原则,编译器会提示编译警告。如下:

double num1 = 100.66;
int num2 = num1; // : warning C4244: “初始化”:从“double”转换到“int”,可能丢失数据

如果我们不想看到警告,可以选择强制类型转换。如下:

double num1 = 100.66;
int num2 = (int)num1;
1.2 自定义数据类型

隐式类型转换的风险一般存在于自定义类型转换间。尤其需要注意自定义类的构造函数。例如:

 class MyString
{
   
public:
    MyString(int n) {
   }; // 本意:预先分配n个字节给字符串
    MyString(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值