C++的类型转换详细介绍
1、类型转换名称和语法
C风格的强制类型转换(Type Cast)很简单,不管什么类型的转换统统是:
TYPE b = (TYPE)a
C++风格的类型转换提供了4种类型转换操作符来应对不同场合的应用。
static_cast 静态类型转换。如int转换成char
reinterpreter_cast 重新解释类型
dynamic_cast 命 名上理解是动态类型转换。如子类和父类之间的多态类型转换。
const_cast 字面上理解就是去const属性。
4种类型转换的格式:
TYPE B = static_cast<TYPE> (a)
2、类型转换一般性介绍
4中类型转化介绍
1)static_cast<>() 静态类型转换,编译的时c++编译器会做类型检查;
基本类型能转换 但是不能转换指针类型
2)若不同类型之间,进行强制类型转换,用reinterpret_cast<>() 进行重新解释
3)dynamic_cast<>(),动态类型转换,安全的基类和子类之间转换;运行时类型检查 (C++特有的)
4)const_cast<>(),去除变量的只读属性(C++特有的),变量的类型必须是指针,指针指向的内存空间可被修改
一般性结论
C语言中 能隐式类型转换的,在c++中可用 static_cast<>()进行类型转换。因C++编译器在编译检查一般都能通过;
C语言中不能隐式类型转换的,在c++中可以用 reinterpret_cast<>() 进行强行类型 解释。
static_cast<>()和reinterpret_cast<>() 基本上把C语言中的 强制类型转换给覆盖
reinterpret_cast<>()很难保证移植性。
3、典型案例
代码中包含了4中类型转化的实例,以及注意点。
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
#include<iostream> using namespace std; class Animal { public : virtual void action() { cout<< "the action is animal's " <<endl; } }; class Dog: public Animal { public : virtual void action() { cout<< "the action is dog's " <<endl; } void doSwim() { cout<< "the dog is swimming..." <<endl; } }; class Cat: public Animal { public : virtual void action() { cout<< "the action is cat's " <<endl; } void doTree() { cout<< "the cat is claming tree..." <<endl; } }; class Desk { public : void action() { cout<< "this is Desk, not belong Animal" <<endl; } }; void ObjPlay(Animal *animl) { animl->action(); Dog *dog = dynamic_cast<Dog *>(animl); if (dog!=NULL) //判断是不是dog { dog->action(); dog->doSwim(); } Cat *cat = dynamic_cast<Cat *>(animl); if (cat!=NULL) //判断是不是cat { cat->action(); cat->doTree(); } cout<< "func ObjPlay is exit!!!\n" <<endl; } //典型用法 把形参的只读属性去掉 void Opbuf( const char *p) { cout << p << endl; //char *p2 = p; err:const char *不能初始化为char * //p[0] = 'b'; err:必须是可修改的左值 char *p2 = const_cast< char *>(p); //去除只读的属相 p2[ 0 ] = 'b' ; cout << p << endl; } int main() { //静态类型转化 static_cast<>() double d = 3.14159 ; int i1,i2; i1 = d; //C中的隐式类型转化 i2 = static_cast< int >(d); //C++中的静态类型转化 cout<< "C中类型转化:" <<i1<<endl; cout<< "C++中类型转化:" <<i2<<endl; //重新解释类型reinterpret_cast<>() char *p = "abcd" ; int *p1 = NULL; int *p2 = NULL; p1 = ( int *)p; //C中强制类型转化 //p2 = static_cast<int *>(p); 编译报错,类型转化错误,静态类型不能转化指针 p2 = reinterpret_cast< int *>(p); //C++中的重新解释类型 cout<< "C中类型转化" <<hex<<*p1<<endl; cout<< "C++中类型转化:" <<hex<<*p2<<endl; //动态类型转换 dynamic_cast<>() Animal an; Animal *pAn = &an; ObjPlay(pAn); Dog dog; Dog *pDog = &dog; ObjPlay(pDog); Cat cat; Cat *pCat = &cat; ObjPlay(pCat); Desk desk; Desk *pDesk = &desk; //Animal *pAn = dynamic_cast<Animal*>(pDesk); 不同的基类指针之间不能相互转化,安全 //去除变量的只读属性,const_cast<>(),此类型必须是指针 char buf[ 100 ] = "aaaaaaaaaaaa" ; //Opbuf(buf); //要保证指针所执行的内存空间能修改才行 若不能修改 还是会引起程序异常 //Opbuf("dddddddddddsssssssssssssss"); system( "pause" ); return 0 ; } |
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:https://my.oschina.net/u/1783725/blog/700970