C++中的const_cast/static_cast/reinterpret_cast/dynamic_cast四种类型转化

文章介绍了C++中的四种类型转换方法:const_cast用于去除常量属性,static_cast提供安全类型转换,reinterpret_cast强制类型转换类似C风格,而dynamic_cast在继承和RTTI中用于对象上下转化。通过实例展示了这些转换的使用场景和注意事项。

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

C++四种类型转化

const_cast:去掉常量属性的一个类型转化。
static_cast:提供编译器认为安全的类型转化,(没有任何联系的类型之间的转化就被否定)。
reinterpret_cast:类似于C风格的强制类型转化。
dynamic_cast:主要用在继承结构,可以支持RTTI类型识别的上下转化。

const_cast括号中的内容必须放 指针类型或者引用类型 。const_cast 中的类型必须是指针、引用或指向对象类型成员的指针。

const int a = 10;
   
//两者在汇编成面上没有明显的区别
int* p1 = (int*)&a;
int* p2 = const_cast<int*>(&a);
//const cast 中的类型必须是指针、引用或指向对象类型成员的指针
//int b = const_cast<int> a;
int b = 20;
int* p3 = const_cast<int*>(&b);

转化主要是使用static_cast进行转化,一般类型都能转化。reinterpret_cast强制转化,和C语言风格的转化无明显区别。

int a = 10;
int b = static_cast<int>(a);

int* p1 = nullptr;
char c = static_cast<char>(a);
//char* p2 = static_cast<char*>(a); 没有类型之间显示关系就无法转化
char* p2 = reinterpret_cast<char*>(&a);//C风格的强制转化,不安全的
char* p3 = (char*)(&a);//和上面的reinterpret一致

dynamic_cast支持对象RTTI的转化,能在派生类对象转化为基类对象后,在识别出原始的派生类对象信息。下面代码提供了一个示例。

#include<iostream>
using namespace std;
class Base
{
public:
	virtual void func() { cout << "Base::func" << endl; }
};
class Derive1 :public Base
{
public:
	virtual void func() { cout << "Derive1:func" << endl; }
};
class Derive2 :public Base
{
public:
	virtual void func() { cout << "Derive2:func" << endl; }
	virtual void change_func() { cout << "Derive2:change_func" << endl; }

};
void func(Base* p)
{
	//如果转化成功那么temp就不为nullptr,否则就为nullptr
	Derive2* temp = dynamic_cast<Derive2*>(p);
	if (temp != nullptr)
	{
		temp->change_func();
	}
	else
	{
		p->func();
	}
}

int main()
{
	Derive1 d1;
	Derive2 d2;
	func(&d1);
	func(&d2);
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Trouble..

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值