很多朋友向小编了解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++中有四种强制类型转换
- static_cast
- reinterpret_cast
- const_cast
- dynamic_cast
static_cast静态转换,任何标准转换都可以用它,但是不能用于两个不相关的类型转换,其实就是有点像隐式类型转换了。
int main()
{
int i = 97;
char ch = static_cast<char>(i);
cout << "i = " << i << endl;
cout << "ch = " << ch << endl;
return 0;
}
reinterpret_cast
reinterpret_cast:将一种类型转换为另外一种类型,但是如果是相关类型则不可以转换,会报错,无效类型转换。
int main()
{
int i = 97;
// char ch = reinterpret_cast<char>(i); // Error 这样的转换类型属于无效转换类型
int* p = reinterpret_cast<int*>(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++强制类形转换内容请搜索编程学习网以前的文章希望大家以后多多支持编程学习网!
本文标题为:一文搞懂C++中的四种强制类型转换
- C语言详解float类型在内存中的存储方式 2023-03-27
- ubuntu下C/C++获取剩余内存 2023-09-18
- Easyx实现扫雷游戏 2023-02-06
- c++ const 成员函数,返回一个 const 指针.但是返回的指针是什么类型的 const? 2022-10-11
- Qt计时器使用方法详解 2023-05-30
- 详解C语言中sizeof如何在自定义函数中正常工作 2023-04-09
- C语言手把手带你掌握带头双向循环链表 2023-04-03
- C++ 数据结构超详细讲解顺序表 2023-03-25
- C语言qsort()函数的使用方法详解 2023-04-26
- 我应该为我的项目使用相对包含路径,还是将包含目录放在包含路径上? 2022-10-30