当前位置: 首页 > news >正文

C++中的四种强制转换

static_cast

原型:static_cast<type-id>(expression)            type-id表示目标类型,expression表示要转换的表达式

static_cast用于非多态类型的转换(静态转换),编译器隐式执行的任何类型转换都可用static_cast,但它不能用于两个不相关的类型进行转换。

int main()
{double d = 12.34;int a = static_cast<int>(d);cout<<a<<endl;return 0;
}

static_cast的相关类型通常包括以下几种情况:

1、隐式类型允许的数值类型转换

基础数据类型之间的转换,比如int→float,double→int等,只要不丢失精度或存在明确的数值转换规则。

枚举类型与整数之间的转换:将枚举值(enum)转换为其底层整数类型(如int)。

空指针(nullptr)到其他指针类型的转换,例如nullptr→int*

int a = 10;
float b = static_cast<float>(a);  // int → float
enum Color { Red, Green };
int c = static_cast<int>(Color::Red);  // 枚举 → int

2、类层次中的上行或下行转换

上行转换:将派生类指针/引用转换为基类指针/引用(安全且无需显示检查)

下行转换:将基类指针/引用转换为派生类指针/引用(需程序员宝成对象类型正确,否则不安全)

class Base {};
class Derived : public Base {};Derived d;
Base* b_ptr = static_cast<Base*>(&d);  // 上行转换(安全)Base* base = new Derived();
Derived* derived = static_cast<Derived*>(base);  // 下行转换(需确保 base 实际指向 Derived)

3、用户定义的转换操作符

如果类定义了自定义的类型转换运算符operator TargetType(),static_cast可以显式调用这些转换。

class MyInt {
public:operator int() const { return value; }  // 自定义转换到 intint value = 42;
};MyInt mi;
int x = static_cast<int>(mi);  // 调用 MyInt::operator int()

4、void*与具体类型指针的转换

将void*转换为具体类型指针(需确保原始指针类型匹配)

将具体类型指针转换为void*(通常隐式允许,但可用static_cast显示表达)

int* p = new int(42);
void* vp = static_cast<void*>(p);  // int* → void*
int* p2 = static_cast<int*>(vp);   // void* → int*(需确保 vp 原本是 int*)

reinterpret_cast

reinterpret_cast的原型为:reinterpret_cast<typeid> (expression).type_id必须是一个指针,引用,算术类型,函数指针,成员指针等。

reinterpret_cast操作符通常为操作数的位模式提供较低层次的重新解释,用于将一种类型转换为另一种不同的类型

int main()
{double d = 12.34;int a = static_cast<int>(d);cout << a << endl;// 这里使用static_cast会报错,应该使用reinterpret_cast//int *p = static_cast<int*>(a);int *p = reinterpret_cast<int*>(a);return 0;
}

reinterpret_cast可以把一个整型转换为指针,也可以把一个指针转换为整型。总结来说,reinterpret_cast可以允许任何指针类型(引用)之间的转换,整型与指针类型间的转换以及指针与足够大的整型之间的转换。

const_cast

原型const_cast<type-name>(expression)      其中,type-name表示要转换成的类型,expression是要进行转换的表达式。

const_cast最常用的用途就是删除变量的const属性,方便赋值

void Test ()
{const int a = 2;int* p = const_cast< int*>(&a );*p = 3;cout<<a <<endl;
}

dynamic_cast

其中,T是目标类型,expression是要转换的表达式。

dynamic_cast用于将一个父类对象的指针/引用转换为子类对象的指针或引用(动态转换)

向上转换:子类对象指针/引用→父类指针/引用(不需要转换,赋值兼容规则)

向下转换:父类对象指针/引用→子类指针/引用(用dynamic_cast转换是安全的)

注意:

1、dynamic_cast只能用于父类含有虚函数的类

2、dynamic_cast会先检查是否能转换成功,能成功则转换,不能则返回nullptr

class A
{public :virtual void f(){}
};
class B : public A
{};void fun (A* pa)
{// dynamic_cast会先检查是否能转换成功,能成功则转换,不能则返回B* pb1 = static_cast<B*>(pa);B* pb2 = dynamic_cast<B*>(pa);cout<<"pb1:" <<pb1<< endl;cout<<"pb2:" <<pb2<< endl;
}
int main ()
{A a;B b;fun(&a);fun(&b);return 0;
}

注意

强制类型转换关闭或挂起了正常的类型检查,每次使用强制类型转换前,程序员应该仔细考虑的是否还有其他不同的方法达到同一目的,如果非强制类型转换不可,则应限制强制转换值的作用域,以减少发生错误的机会。

强烈建议:避免使用强制类型转换

相关文章:

  • 掌握版本控制从本地到分布式
  • 动态内存管理2+柔性数组
  • docker-compose部署项目(springboot服务)以及基础环境(mysql、redis等)ruoyi-ry
  • Leetcode134加油站
  • GO语言语法---For循环、break、continue
  • AI图像处理之ComfyUI节点(二)
  • 前缀和——中心数组下标
  • Compose笔记(二十五)--Brush
  • NSString的三种实现方式
  • OpenHarmony外设驱动使用 (四),Face_auth
  • 三极管集电极输出电路分析
  • IT审计之外包
  • 【图像生成大模型】CogVideoX-5b:开启文本到视频生成的新纪元
  • 第三十七节:视频处理-视频读取与处理
  • 常见的 HTTP 接口(请求方法)
  • Uniapp 与 Uniapp X 对比:新手上手指南及迁移到 Uniapp X 的注意事项
  • Word文档图片和图表自动添加序号
  • 19. 结合Selenium和YAML对页面实例化PO对象改造
  • Elasticsearch基础篇-java程序通过RestClient操作es
  • BUUCTF——ReadlezPHP
  • 香港今年新股集资额已超600亿港元,暂居全球首位
  • 英国知名歌手批政府:让AI公司免费使用艺术家作品是盗窃
  • 俄外长与美国务卿通电话,讨论俄美接触等问题
  • 美国考虑让移民上真人秀竞逐公民权,制片人称非现实版《饥饿游戏》
  • 一箭六星,朱雀二号改进型遥二运载火箭发射成功
  • 朝鲜称将在各领域采取反制措施,应对美国敌对挑衅