一文搞懂C++中的四种强制类型转换
在了解c++的强制类形转换的时候,先看看在c语言中是怎么进行强制类形转换的。
C语言中的强制类形转换分为两种
- 隐式类型转换
- 显示类型转换
int main(){ int a = 97; char ch = a; // 隐式类型转换 int b = (int)ch; // 显示类型转换 cout << "a = " << a << endl; cout << "ch = " << ch << endl; cout << "b = " << b << endl; int num = 10; int* p = # // int ret = p; Error,因为p的类型和ret的类型不一致,所以隐式转换失败 int ret = (int)p; cout << "num = " << num << endl; cout << "&num = " << &num << endl; cout << "p = " << p << endl; cout << "ret = " << ret << endl; return 0; }
【一文搞懂C++中的四种强制类型转换】我们看出来,在相关数据类型之间的转换是可以隐式转换的,如果是俩个不相关的数据类型之间的转换,必须是显式类型转换。
C++中的强制类形转换 C++中有四种强制类型转换
- static_cast
- reinterpret_cast
- const_cast
- dynamic_cast
int main(){ int i = 97; char ch = static_cast(i); cout << "i = " << i << endl; cout << "ch = " << ch << endl; return 0; }
reinterpret_cast reinterpret_cast:将一种类型转换为另外一种类型,但是如果是相关类型则不可以转换,会报错,无效类型转换。
int main(){ int i = 97; // char ch = reinterpret_cast(i); // Error 这样的转换类型属于无效转换类型 int* p = reinterpret_cast (i); cout << "i = " << i << endl; cout << "&i = " << &i << endl; cout << "p = " << p << endl; return 0; }
文章图片
这个的输出结果就很意思,我们可以观察到,p 是我们定义的一个 int* 变量,但是我们使用reintrtpret_cast的时候并不是把 i 变量的地址写了进去,而是将 i 变量的值,用 int* 类型的格式存储了起来,也就是说 int* p 的 p 存放的不是 i 的地址,而是,变量 i 的值,只不过是用16进制来存储的。
到此这篇关于C++中的四种强制类形转换的文章就介绍到这了,更多相关C++强制类形转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- opencv|opencv C++模板匹配的简单实现
- C语言学习|第十一届蓝桥杯省赛 大学B组 C/C++ 第一场
- c++基础概念笔记
- 【图解】9张图彻底搞懂堆排序
- mysql|一文深入理解mysql
- 数据技术|一文了解Gauss数据库(开发历程、OLTP&OLAP特点、行式&列式存储,及与Oracle和AWS对比)
- 牛逼!C++开发的穿越丛林真人游戏,游戏未上线就有百万人气
- 一文弄懂MySQL中redo|一文弄懂MySQL中redo log与binlog的区别
- c语言|一文搞懂栈(stack)、堆(heap)、单片机裸机内存管理malloc
- 网络|一文彻底搞懂前端监控