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