static_cast在编译时进行无运行时检查的类型转换,适用于基本类型转换和继承体系中的向上转型;dynamic_cast在运行时通过RTTI检查类型安全性,仅用于多态类型间的向下或跨转型,转换失败返回nullptr或抛出异常;二者主要区别在于检查时机、安全性、性能及适用类型;此外const_cast用于修改const/volatile属性,reinterpret_cast则进行低层位重解释,风险高应慎用。
在C++中,类型转换是将一种数据类型转换为另一种数据类型的操作。为了更安全、更明确地进行类型转换,C++引入了四种强制类型转换操作符:static_cast、dynamic_cast、const_cast 和 reinterpret_cast。本文重点讲解 static_cast 与 dynamic_cast 的区别,并对四种转换方式做全面解析。
static_cast 是在编译时进行的类型转换,适用于大多数“合理”的类型转换场景,但不进行运行时类型检查。
常见用途包括:
示例:
double d = 3.14; int i = static_cast(d); // 基本类型转换 class Base {}; class Derived : public Base {}; Derived pd = new Derived; Base pb = static_cast
(pd); // 向上转型,安全
注意:static_cast 也可用于向下转型(down-cast),但不安全,因为没有运行时检查。如果转换错误,结果是未定义行为。
dynamic_cast 主要用于继承体系中的安全向下转型或跨继承转换,它在运行时进行类型检查,依赖于 RTTI(Run-Time Type Information)。
特点:
示例:
Base* pb = new Derived; Derived* pd = dynamic_cast(pb); if (pd) { // 转换成功,安全使用 pd } else { // 转换失败,原对象不是 Derived 类型 }
与 static_cast 相比,dynamic_cast 更安全,适合不确定对象实际类型时使用。
以下是 static_cast 和 dynamic_cast 的主要区别:
const_cast:用于添加或移除 const、volatile 属性。
典型用途:将 const 指针转换为非 const 指针,以便修改数据(需确保原对象非常量)。
const int ci = 10; int* modifiable = const_cast(&ci); *modifiable = 20; // 危险!原对象是 const,修改导致未定义行为
reinterpret_cast:最危险的转换,进行低层的位模式重新解释。
例如将指针转为整数,或将一种类型指针转为另一种无关类型指针。
int* pi = new int(42); uintptr_t addr = reinterpret_cast(pi); // 指针转整型地址
这种转换高度不可移植,应尽量避免。
基本上就这些。理解每种 cast 的用途和限制,能帮助写出更安全、清晰的 C++ 代码。不复杂但容易忽略细节。