kenwell
自己学习所用
导航
C++博客
首页
新随笔
联系
聚合
管理
<
2024年11月
>
日
一
二
三
四
五
六
27
28
29
30
31
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
1
2
3
4
5
6
7
统计
随笔 - 25
文章 - 4
评论 - 21
引用 - 0
常用链接
我的随笔
我的评论
我参与的随笔
留言簿
(2)
给我留言
查看公开留言
查看私人留言
随笔分类
c++学习中的问题(10)
(rss)
shell(7)
(rss)
stl学习
(rss)
vim(1)
(rss)
算法(4)
(rss)
随笔档案
2010年8月 (5)
2010年6月 (6)
2008年10月 (3)
2008年7月 (2)
2008年6月 (2)
2008年5月 (2)
2007年10月 (1)
2006年11月 (1)
2006年3月 (3)
文章分类
c++学习心得(2)
(rss)
stl学习(1)
(rss)
文章档案
2008年7月 (2)
2006年3月 (2)
c++的好站点
stl中文站
能下吧
电脑书籍下载
最优秀的STL使用学习网站
搜索
最新评论
1. re: Linux Shell Bash 正则表达式介绍[未登录]
评论内容较长,点击标题查看
--Steven
2. re: c++经典书籍推荐和下载
不错 我才 来看不知道晚不晚了
--次奥校
3. essays
In all seriousness, this is quite hilarious and, unfortunately, probably true.
--termpapers99@gmail.com
4. re: 一个n!的数后面有多少个0
评论内容较长,点击标题查看
--thesis service
5. re: 一个n!的数后面有多少个0
评论内容较长,点击标题查看
--buy cheap research paper
阅读排行榜
1. c++ string 和wstring 之间的互相转换函数(29360)
2. c++经典书籍推荐和下载(11442)
3. Linux Shell Bash 正则表达式介绍(7752)
4. c++ 中用IXMLHTTPRequest向服务器post Xml数据(4351)
5. 一个n!的数后面有多少个0(2947)
评论排行榜
1. 一个n!的数后面有多少个0(13)
2. c++经典书籍推荐和下载(8)
3. c++ string 和wstring 之间的互相转换函数(2)
4. Linux Shell Bash 正则表达式介绍(1)
5. shell 变量间接引用(0)
总结C++中的所有强制转换函数(const_cast,reinterpret_cast,static_cast,dynamic_cast)
非常抱歉,谢谢郭老师的指正,我没有认真看这个文章就转过来了,其实他的错误太多了,而且还是致命的,对大家不负责任了,请大家谅解!现在是修正版本,基本没有错误了!如果觉得还有问题,请联系我,谢谢你的关注!
这篇文章其实并不是不才的原创,本来打算自己写的,但是通过baidu一下,发现有兄弟写出来了,就干脆摘录下来,供大家参考使用了!
详情请看:
view plain
print
?
标准
c
++中主要有四种强制转换类型运算符:
const_cast
,
reinterpret_cast
,
static_cast
,
dynamic_cast
等等。
1)
static_cast
<T*>(a)
将地址a转换成类型T,T和a必须是指针、引用、算术类型或枚举类型。
表达式
static_cast
<T*>(a), a的值转换为模板中指定的类型T。在运行时转换过程中,不进行类型检查来确保转换的安全性。
例子:
class
B { ... };
class
D :
public
B { ... };
void
f(B* pb, D* pd)
{
D* pd2 =
static_cast
<D*>(pb);
// 不安全, pb可能只是B的指针
B* pb2 =
static_cast
<B*>(pd);
// 安全的
...
}
class
B { ... };
class
D :
public
B { ... };
void
f(B* pb, D* pd)
{
D* pd2 =
static_cast
<D*>(pb);
// 不安全, pb可能只是B的指针
B* pb2 =
static_cast
<B*>(pd);
// 安全的
...
}
class
B { ... };
class
D :
public
B { ... };
void
f(B* pb, D* pd)
{
D* pd2 =
static_cast
<D*>(pb);
// 不安全, pb可能只是B的指针
B* pb2 =
static_cast
<B*>(pd);
// 安全的
...
}
2)
dynamic_cast
<T*>(a)
完成类层次结构中的提升。T必须是一个指针、引用或无类型的指针。a必须是决定一个指针或引用的表达式。
表达式
dynamic_cast
<T*>(a) 将a值转换为类型为T的对象指针。如果类型T不是a的某个基类型,该操作将返回一个空指针。
例子:
class
A { ... };
class
B { ... };
void
f()
{
A* pa =
new
A;
B* pb =
new
B;
void
* pv =
dynamic_cast
<A*>(pa);
// pv 现在指向了一个类型为A的对象
...
pv =
dynamic_cast
<B*>(pb);
// pv 现在指向了一个类型为B的对象
}
3)
const_cast
<T*>(a)
去掉类型中的常量,除了
const
或不稳定的变址数,T和a必须是相同的类型。
表达式
const_cast
<T*>(a)被用于从一个类中去除以下这些属性:
const
,
volatile
, 和 __unaligned。
例子:
class
A { ... };
void
f()
{
const
A *pa =
new
A;
//const对象
A *pb;
//非const对象
//pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
pb =
const_cast
<A*>(pa);
// 现在OK了
...
}
class
A { ... };
void
f()
{
const
A *pa =
new
A;
//const对象
A *pb;
//非const对象
//pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
pb =
const_cast
<A*>(pa);
// 现在OK了
...
}
class
A { ... };
void
f()
{
const
A *pa =
new
A;
//const对象
A *pb;
//非const对象
//pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象
pb =
const_cast
<A*>(pa);
// 现在OK了
...
}
4)
reinterpret_cast
<T*>(a)
任何指针都可以转换成其它类型的指针,T必须是一个指针、引用、算术类型、指向函数的指针或指向一个类成员的指针。
表达式
reinterpret_cast
<T*>(a)能够用于诸如
char
* 到
int
*,或者One_class* 到 Unrelated_class*等类似这样的转换,因此可能是不安全的。
例子:
class
A { ... };
class
B { ... };
void
f()
{
A* pa =
new
A;
void
* pv =
reinterpret_cast
<A*>(pa);
// pv 现在指向了一个类型为B的对象,这可能是不安全的
...
}
标准c++中主要有四种强制转换类型运算符: const_cast,reinterpret_cast,static_cast,dynamic_cast等等。 1)static_cast<T*>(a) 将地址a转换成类型T,T和a必须是指针、引用、算术类型或枚举类型。 表达式static_cast<T*>(a), a的值转换为模板中指定的类型T。在运行时转换过程中,不进行类型检查来确保转换的安全性。 例子: class B { ... }; class D : public B { ... }; void f(B* pb, D* pd) { D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针 B* pb2 = static_cast<B*>(pd); // 安全的 ... } class B { ... }; class D : public B { ... }; void f(B* pb, D* pd) { D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针 B* pb2 = static_cast<B*>(pd); // 安全的 ... } class B { ... }; class D : public B { ... }; void f(B* pb, D* pd) { D* pd2 = static_cast<D*>(pb); // 不安全, pb可能只是B的指针 B* pb2 = static_cast<B*>(pd); // 安全的 ... } 2)dynamic_cast<T*>(a) 完成类层次结构中的提升。T必须是一个指针、引用或无类型的指针。a必须是决定一个指针或引用的表达式。 表达式dynamic_cast<T*>(a) 将a值转换为类型为T的对象指针。如果类型T不是a的某个基类型,该操作将返回一个空指针。 例子: class A { ... }; class B { ... }; void f() { A* pa = new A; B* pb = new B; void* pv = dynamic_cast<A*>(pa); // pv 现在指向了一个类型为A的对象 ... pv = dynamic_cast<B*>(pb); // pv 现在指向了一个类型为B的对象 } 3)const_cast<T*>(a) 去掉类型中的常量,除了const或不稳定的变址数,T和a必须是相同的类型。 表达式const_cast<T*>(a)被用于从一个类中去除以下这些属性:const, volatile, 和 __unaligned。 例子: class A { ... }; void f() { const A *pa = new A;//const对象 A *pb;//非const对象 //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象 pb = const_cast<A*>(pa); // 现在OK了 ... } class A { ... }; void f() { const A *pa = new A;//const对象 A *pb;//非const对象 //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象 pb = const_cast<A*>(pa); // 现在OK了 ... } class A { ... }; void f() { const A *pa = new A;//const对象 A *pb;//非const对象 //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象 pb = const_cast<A*>(pa); // 现在OK了 ... } 4)reinterpret_cast<T*>(a) 任何指针都可以转换成其它类型的指针,T必须是一个指针、引用、算术类型、指向函数的指针或指向一个类成员的指针。 表达式reinterpret_cast<T*>(a)能够用于诸如char* 到 int*,或者One_class* 到 Unrelated_class*等类似这样的转换,因此可能是不安全的。 例子: class A { ... }; class B { ... }; void f() { A* pa = new A; void* pv = reinterpret_cast<A*>(pa); // pv 现在指向了一个类型为B的对象,这可能是不安全的 ... }
如果不明白,可以给我留言!
posted on 2008-07-22 10:07
c++ 学习
阅读(324)
评论(0)
编辑
收藏
引用
只有注册用户
登录
后才能发表评论。
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
网站导航:
博客园
IT新闻
BlogJava
知识库
博问
管理