forked from hengqiali/AwesomeCpp
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path四种cast
91 lines (73 loc) · 3.76 KB
/
四种cast
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
#include <iostream>
/*********************************************
C++ static_cast const_cast dynamic_cast reinterpret_cast
*********************************************/
void foo(int *num) //用于测试const_cast
{
std::cout << "const_cast函数参数测试 " << *num << std::endl;
}
int main()
{
/******** static_cast *********/
// 1. 强制类型转换,从大类型转换到小类型和从小类型转换到大类型都可以
// 2. 找回void *指针中存在的值
double a = 5.3;
int b = static_cast<int>(a);
const char *cp = "hq";
// 1. 强制类型转换
std::cout << b << std::endl;
std::string scp = static_cast<std::string>(cp);
std::cout << scp << std::endl;
// 2. 找回void *指针中存在的值
void *p = &a;
double *dp = static_cast<double *>(p);
std::cout << *dp << std::endl;
/******** const_cast *********/
// 1. const_cast绝对不能改变const修饰的常量的值
// 2. 当一个量定义为const,函数形参要求是non_const时,可使用const_cast去掉const传递
// 3. 当一个量是non_const,却使用一个const指针指向它,若需要修改其,使用const_cast
// 1. const_cast绝对不能改变const修饰的常量的值
const int constant = 25; //如果带const不能通过去const指针来修改
//int constant = 25; // 3. 当一个量是non_const,却使用一个const指针指向它,若需要修改其,使用const_cast
const int *constant_p = &constant;
int *modify = const_cast<int *>(constant_p);
*modify = 3;
std::cout << "constant = " << constant << std::endl;
std::cout << "*modify = " << *modify << std::endl;
/* 错误,const_cast一般对指针去const
int modify_2 = const_cast<int>(constant);
modify_2 = 6;
std::cout << "constant = " << constant << std::endl;
std::cout << "modify_2 = " << modify_2 << std::endl;
*/
// 2. 当一个量定义为const,函数形参要求是non_const时,可使用const_cast去掉const传递
//foo(&constant); //error: invalid conversion from 'const int*' to 'int*' [-fpermissive]|
foo(const_cast<int *>(&constant));
/******** reinterpret_cast *********/
//什么类型转换都可以实现,但是其不会改变值,但是会从位模式上重新解释原来的值,可能会造成结果不一致,所以不建议使用
//https://zhuanlan.zhihu.com/p/33040213
int num = 0x00636261;
int *pnum = #
//char *psnum = pnum; //出错,不能直接转换
char *ps2num = reinterpret_cast<char *> (pnum);
//char *ps3num = static_cast<char *>(pnum); //出错,不允许int*到char*的强制转换
cout << hex << *pnum << endl;
//cout << *psnum << endl;
cout << *ps2num << endl;
cout << ps2num << endl;
//cout << ps3num << endl;
//double *dum = pnum; //出错,不能直接转换
double *dnum = reinterpret_cast<double*>(pnum);
//double *d2num = static_cast<double*>(pnum); //出错,不允许int*到double*的强制转换
cout << *dnum << endl;
//cout << *d2num << endl;
/******** dynamic_cast *********/
//用于多态类型之间进行转换,支持向上,向下、横向类型间转换,在执行期会动态检查安全性
//https://www.cnblogs.com/weidagang2046/archive/2010/04/10/1709226.html
//https://blog.csdn.net/hongkangwl/article/details/21161713
/*************** 为什么不用C语言的强制转换方式呢?? ************/
1) 首先C语言的强制类型转换不够明确,比较暴力,不能进行错误检查,容易出错;
C++的强制类型转换可能根据需求不同选择不同的cast进行转换
2) 同时,C++的强制转换提供了类型转换安全检查,且功能强大
return 0;
}