【1】 const_cast的作用

一、常量指针 被强转为 非常量指针,且仍然指向原来的对象;

二、常量引用 被强转为 非常量引用,且仍然指向原来的对象;

三、常量对象 被强转为 非常量对象。

【2】 实例代码

代码如下:

 #include <iostream>
using namespace std; const int xx = ; class A
{
public:
int m_nNum; public:
A(int nValue = );
}; A::A(int nValue) : m_nNum(nValue)
{
} void TestFun()
{
// 第一种情况: const修饰指针指向对象
const A *pA = new A();
// pA->m_nNum = 100; // compile error ! pA指针指向的对象为常对象,其成员变量值为只读的。
A* pAA = const_cast<A*>(pA); // 去掉pA指针的const属性
pAA->m_nNum = ; // pAA指针指向的对象为一般对象,其成员变量值可读写。
cout << pA->m_nNum << endl; // 199 // 第二种情况: const修饰指针
A *pB = new A();
pA = pB; // 思考这个原因。为什么这样子可以呢?且再看下面的这种情况:
A* const pC = new A();
cout << pC->m_nNum << endl; //
A *pD = new A();
// pC = pD; // compile error ! pC指针变量被const修饰,其值是只读的。 A*& pE = const_cast<A*>(pC); // 去掉pC指针变量的const属性。再赋给指针引用变量
pE = pD;
cout << pC->m_nNum << endl; // A* pAS = const_cast<A*>(pC); // 去掉pC指针变量的const属性。再赋给一般指针变量
pAS->m_nNum = ; // 通过去掉const属性的指针变量修改其成员变量值
cout << pC->m_nNum << endl; // 3 // 第三种情况:const修饰指针和指针对象
const A* const pCC = new A();
const A* pCC2 = const_cast<A*>(pCC);
// pCC2->m_nNum = 119; // error C3490: 由于正在通过常量对象访问“m_nNum”,因此无法对其进行修改
pCC2 = NULL;
A* const pCC3 = const_cast<A*>(pCC);
pCC3->m_nNum = ;
// pCC3 = NULL; error C3892: “pCC3”: 不能给常量赋值
A* pCC4 = const_cast<A*>(pCC);
pCC4->m_nNum = ;
pCC4 = NULL; // 第四种情况:const修饰对象,去const属性后赋给一般对象
const A a;
// a.m_nNum = 101; // compile error ! 常对象具有只读属性。
A b = const_cast<A&>(a);
b.m_nNum = ;
cout << a.m_nNum << endl; //
cout << b.m_nNum << endl; // 101 // 第五种情况:const修饰对象,去const属性后赋给引用对象
const A c;
// c.m_nNum = 101; // compile error ! 常对象具有只读属性。
A& d = const_cast<A&>(c);
d.m_nNum = ;
cout << c.m_nNum << endl; //
cout << d.m_nNum << endl; // 102 // 第六种情况:const修饰对象,对象指针去const属性后赋给指针
const A e;
// e.m_nNum = 103; // compile error ! 常对象具有只读属性。
A* pe = const_cast<A*>(&e);
pe->m_nNum = ;
cout << e.m_nNum << endl; //
cout << pe->m_nNum << endl; // 103 // 第七种情况:const修饰局部变量
const int xx = ;
int* yy = const_cast<int *>(&xx);
*yy = ;
cout << xx << endl; //
cout << *yy << endl; //
int aa = xx;
cout << aa << endl; // 50 // 第八种情况:const修饰局部变量。去const属性后赋给一般变量
const int xxx = ;
int yyy = const_cast<int&>(xxx);
yyy = ;
cout << xxx << endl; //
cout << yyy << endl; // 51 // 第九种情况:const修饰局部变量。去const属性后赋给引用变量
const int xxx2 = ;
int& yyy2 = const_cast<int&>(xxx2);
yyy2 = ;
cout << xxx2 << endl; //
cout << yyy2 << endl; //
} void main()
{
TestFun();
system("pause");
} // run out:
/*
199
1
2
3
100
101
102
102
103
103
50
200
50
50
51
50
52
请按任意键继续. . .
*/

Good Good Study, Day Day Up.

顺序 选择 循环 总结

强制类型转换(const_cast)的更多相关文章

  1. C++强制类型转换操作符 const_cast

    const_cast也是一个强制类型转换操作符.<C++ Primer>中是这样描述它的: 1.将转换掉表达式的const性质. 2.只有使用const_cast才能将const性质性质转 ...

  2. c++强制类型转换:dynamic_cast、const_cast 、static_cast、reinterpret_cast

    c++强制类型转换:dynamic_cast.const_cast .static_cast.reinterpret_cast 博客分类: C/C++ CC++C#编程数据结构  dynamic_ca ...

  3. C++强制类型转换:static_cast、dynamic_cast、const_cast、reinterpret_cast

    1. c强制转换与c++强制转换 c语言强制类型转换主要用于基础的数据类型间的转换,语法为: (type-id)expression//转换格式1 type-id(expression)//转换格式2 ...

  4. 四种强制类型转换的总结(const_cast、static_cast、dynamic_cast、reinterpreter_cast)

    四种强制类型转换的总结(const_cast.static_cast.dynamic_cast.reinterpreter_cast) 转载 2011年10月03日 23:59:05 标签: stru ...

  5. C++里的强制类型转换符reinterpret_cast、static_cast 、dynamic_cast、const_cast 区别

    C 风格(C-style)强制转型如下: (T) exdivssion // cast exdivssion to be of type T 函数风格(Function-style)强制转型使用这样的 ...

  6. C++强制类型转换

    C语言强制类型转换过于粗暴,任意类型之间都可以进行转换,编译很难判断其正确性; 难于定位,在源码中无法快速定位所有使用强制类型转换的语句. C++将强制类型转换分为4种不同的类型:static_cas ...

  7. C++强制类型转换操作符 static_cast

    static_cast是一个强制类型转换操作符.强制类型转换,也称为显式转换,C++中强制类型转换操作符有static_cast.dynamic_cast.const_cast.reinterpert ...

  8. C++的几种强制类型转换

    有时我们希望显式地将对象强制类型转换成另外一种类型.例如,如果想在下面的代码中执行浮点数除法: int i, j; double slope = i / j; 就要使用某种方法将i和/或j显式地转换成 ...

  9. C++开发必看 四种强制类型转换的总结 [转]

    一.C风格的强制类型转换(Type Cast)很简单,不管什么类型的转换统统是:     TYPE b = (TYPE)a 二.C++风格的类型转换提供了4种类型转换操作符来应对不同场合的应用. co ...

随机推荐

  1. synchronized原理

    http://www.cnblogs.com/YDDMAX/p/5658607.html http://www.cnblogs.com/YDDMAX/p/5658668.html synzhroniz ...

  2. jQuery中的bind() live() delegate()之间区别分析

    jQuery中的bind() live() delegate()之间区别分析 首先,你得要了解我们的事件冒泡(事件传播)的概念,我先看一张图 1.bind方式 $('a').bind('click', ...

  3. iOS Block浅析

    Block 的使用有两种:1.独立Block .2.内联Block .   <一>独立Block 使用方式   一.定义一个Block Object,并调用.   1.定义   // 定义 ...

  4. Oracle直方图导致SQL不走索引.

    在ITPUB 上看到一个帖子 http://www.itpub.net/thread-1875212-1-1.html 同一条SQL语句,只有查询条件不一样,查询返回的结果集都为0,一个走了全表扫描, ...

  5. hibernate一对多注解

    package net.zmcheng.model; import java.util.HashSet;import java.util.Set; import javax.persistence.C ...

  6. 修改了系统自带头文件后,Xcode会报错

    1.Xcode自带头文件的路径 /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Develo ...

  7. Spring Boot flyway的启动时机比较早

    flyway,如果已经创建的版本V1中已经更新,则会validation报错 at org.springframework.boot.devtools.restart.RestartLauncher. ...

  8. 统计哪些程序占用了swap

    命令如下 : for i in `cd /proc;ls |grep "^[0-9]"|awk ' $0 >100'` ;do awk '/Swap:/{a=a+$2}END ...

  9. JAVA字符串的GZIP压缩解压缩

    package com.gzip; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import ...

  10. Java数据库操作大全

    1.提取单条记录 //import java.sql.*; Connection con=null; Statement stmt=null; ResultSet %%6=null; try { Cl ...