C
语言中的类型转换
- 在C语言中,如果赋值运算符左右两侧类型不同,或者形参与实参类型不匹配,或者返回值类型与接收返回值类型不一致时,就需要发生类型转化,C语言中总共有两种形式的类型转换:
- 隐式类型转换
- 编译器在编译阶段自动进行,能转就转,不能转就编译失败
- 显式类型转换
void Test ()
{
int i = 1;
// 隐式类型转换
double d = i;
printf("%d, %.2f\n" , i, d);
int* p = &i;
// 显示的强制类型转换
int address = (int) p;
printf("%x, %d\n" , p, address);
}
缺陷: 转换的可视性比较差,所有的转换形式都是以一种相同形式书写,难以跟踪错误的转换
为什么
C++
需要四种类型转换
- C风格的转换格式很简单,但是有不少缺点的:
- 隐式类型转化有些情况下可能会出问题:比如数据精度丢失
- 显式类型转换将所有情况混合在一起,代码不够清晰
因此C++提出了自己的类型转化风格,注意因为C++要兼容C语言,所以C++中还可以使用C语言的转化风格。
C++
强制类型转换
int main()
{
double d = 12.34;
int a = static_cast<int>(d);
cout<<a<<endl;
return 0;
}
typedef void (* FUNC)();
int DoSomething (int i)
{
cout<<"DoSomething" <<endl;
return 0;
}
void Test ()
{
//
// reinterpret_cast可以编译器以FUNC的定义方式去看待DoSomething函数
// 所以非常的BUG,下面转换函数指针的代码是不可移植的,所以不建议这样用
// C++不保证所有的函数指针都被一样的使用,所以这样用有时会产生不确定的结果
//
FUNC f = reinterpret_cast<FUNC>(DoSomething);
f();
}
void Test ()
{
const int a = 2;
int* p = const_cast< int*>(&a);
*p = 3;
cout<< a <<endl;
}
强烈建议:避免使用强制类型转换
explicit
- explicit关键字阻止经过转换构造函数进行的隐式转换的发生
RTTI
- RTTI:Run-time Type identifification的简称,即:运行时类型识别。
- C++通过以下方式来支持RTTI:
- ?typeid运算符
- dynamic_cast运算符
?
|