C++类型转换运算符的实例详解
C++类型转换运算符的实例详解
C++中有4个类型转换运算符,使装换过程更规范
dynamic_cast;
const_cast;
static_cast;
reinterpret_cast;
一、dynamic_cast
该运算符我在之前的文章中已经介绍过了
//www.jb51.net/article/123252.htm
总之,该运算符的语法如下:
dynamic_cast < type-name> (expression)
如果转型失败则返回0,即空指针。
该运算符的用途是,使得能够在类层次结构中进行向上转换(由于 is-a关系,这样的类型转换时安全的),而不允许其他转换。
二、const_cast
const_cast运算符用于执行只有一种用途的类型转换,即改变值为const 或 volatile,其语法与dynamic_cast运算符相同。
const_cast < type-name > (expression)
如果类型的其他方面也被修改,则上述类型转换将出错。也就是说,除了const或volatile特征(有或无)可以不同外,type_name 和expression的类型必须相同
另外const_cast不是万能的。它可以修改指向一个值的指针,但修改const值的结果是不确定的。
using std::cout; using std::endl; void change(const int *pt, int n); int main() { int pop1 = 38383; const int pop2 = 2000; cout << "pop1,pop2: " << pop1 << " , " << pop2 << endl; change(&pop1, -103); change(&pop2, -103); cout << " pop1, pop2: " << pop1 << " , " << pop2 << endl; system("pause"); return 0; } void change(const int *pt, int n) { int *pc; pc = const_cast<int *>(pt); *pc += n; }
运行结果:
pop1,pop2: 38383 , 2000 pop1, pop2: 38280 , 2000 请按任意键继续. . .
可以看到调用change()时,修改了pop1,但没有修改pop2。咋change()中,指正被声明为const int * ,因此不能用来修改指向的 int 。指针pc删除了 const特性,因此可用来修改指向的值,但仅当执行的值不少const时才行,因此,pc可用来修改pop1,单不能修改pop2.
三、static_cast
static_cast运算符的语法与其他类型转换运算符相同
static_cast< type-name > (expression)
仅当 type-name可被隐式转换为expression所属类型或expression可被隐式转换为type-name所属的类型时,上述转换才是合法的,否则将出错。
High bar; Low blow; ... High *pb = static_cast<High *>( &blow) //合法 Low *pl = static_cast< Low *> (&bar) //合法 Pond *pmer = static_cast< Pond * > (& blow) ;//非法
四、reinterpret_cast
reinterpret_cast运算符用于天生危险的类型转换。
用法:
reinterpret_cast < type-name >(expression)
示例:
struct dat {short a;short b;} ; long value = 0xA224B118; dat * pd = reinterpret_cast <dat *> (&value); cout <<hex <<pd->a ; //显示前2个字节的值
然而,reinterpret_cast运算符并不支持所有的类型转换。例如,可以将指针类型转换为足以存储指针表示的整形,但不能将指针转换为更小的整型或浮点型。另一个限制是,不能将函数指针转换为数据指针,反之亦然。
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章
- 04-02c语言没有round函数 round c语言
- 01-10深入理解C++中常见的关键字含义
- 01-10使用C++实现全排列算法的方法详解
- 01-10c++中inline的用法分析
- 01-10用C++实现DBSCAN聚类算法
- 01-10全排列算法的非递归实现与递归实现的方法(C++)
- 01-10C++大数模板(推荐)
- 01-10浅谈C/C++中的static与extern关键字的使用详解
- 01-10深入C/C++浮点数在内存中的存储方式详解
- 01-10深入理解C/C++混合编程
阅读排行
本栏相关
- 04-02c语言函数调用后清空内存 c语言调用
- 04-02func函数+在C语言 func函数在c语言中
- 04-02c语言的正则匹配函数 c语言正则表达
- 04-02c语言用函数写分段 用c语言表示分段
- 04-02c语言中对数函数的表达式 c语言中对
- 04-02c语言编写函数冒泡排序 c语言冒泡排
- 04-02c语言没有round函数 round c语言
- 04-02c语言分段函数怎么求 用c语言求分段
- 04-02C语言中怎么打出三角函数 c语言中怎
- 04-02c语言调用函数求fibo C语言调用函数求
随机阅读
- 04-02jquery与jsp,用jquery
- 01-11ajax实现页面的局部加载
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 01-10SublimeText编译C开发环境设置
- 01-10C#中split用法实例总结