修改const常量的方法
2010-10-12 22:45
369 查看
看到这个标题,你也许会说,我不懂const, 因为Const修饰的是不可变得变量,他的值是不能修改的。没错,const修改的值的确不能修改,但是也有条件,条件就是编译不能通过,const是一个编译时期常量。如果我能在绕过编译器,通过编译后,我仍然可以修改const的值。
分C/C++两种情况讨论:
一 C语言:
const long lng=10;
long *pl=(long)&lng;
*pl=1000;
cout<<*pl<<endl;//输出1000
cout<<lng<<endl;//输出10
这是什么原因呢?因为const的值是放在一个符号表中存储的,只读的。编译器会在内存中重新在内存中创建它的一个拷贝,通过地址访问到的是这个拷贝,而不是原始值。
二 C++语言:
class Integer
{
public:
Integer():m_lng(100){}
long m_lng;
}
const Integer int_l;
Integer *pInt=(Integer*)&int_l;
pInt->m_lng=1000;
cout<<pInt->m_lng<<endl;//1000
cout<<int_l.m_lng<<endl;//1000修改成功
由此可以看出,const只是编译时期的一种强类型安全检查机制的一种手段,他只是帮组我们发现无意中修改的常量,无法在二进制层面进行保护。
分C/C++两种情况讨论:
一 C语言:
const long lng=10;
long *pl=(long)&lng;
*pl=1000;
cout<<*pl<<endl;//输出1000
cout<<lng<<endl;//输出10
这是什么原因呢?因为const的值是放在一个符号表中存储的,只读的。编译器会在内存中重新在内存中创建它的一个拷贝,通过地址访问到的是这个拷贝,而不是原始值。
二 C++语言:
class Integer
{
public:
Integer():m_lng(100){}
long m_lng;
}
const Integer int_l;
Integer *pInt=(Integer*)&int_l;
pInt->m_lng=1000;
cout<<pInt->m_lng<<endl;//1000
cout<<int_l.m_lng<<endl;//1000修改成功
由此可以看出,const只是编译时期的一种强类型安全检查机制的一种手段,他只是帮组我们发现无意中修改的常量,无法在二进制层面进行保护。
相关文章推荐
- 修改const常量的方法
- 指针与字符串:(const)char *p2 = "lmj";定义的是一个字符串常量!符串常量,正因为是常量,所以它内部的字符是不允许修改的。
- 修改常量指针所指向变量的方法
- 能否通过内嵌汇编修改C++中const常量的值
- C++类静态成员变量和const常量的初始化方法
- const常量引用的使用方法
- C++类静态成员变量和const常量的初始化方法
- C++中常量指针,指针常量(const 和*)的使用方法和理解方法
- db2 将原表列notnull属性修改为null属性的方法 (查看主键约束,唯一约束去syscat.tabconst)
- const常量的修改问题
- 市场售价 本店售价 促销价格等系统常量的修改方法[ecshop,模板二次开发]
- C++中修改常量值的方法
- A.4-继承,方法重写(覆盖)(override),虚函数(virtaul)和多态,抽象方法和抽象类abstract,密封类(sealed)和密封方法,常量的定义(const)
- C++11特有的数值、数组初始化方法、常量的符号名称 const和浮点数、bool、自动推断类型auto
- const在函数和方法上的防修改作用
- VC++类静态成员变量和const常量的初始化方法
- const修饰的常量 不能被直接修改 但是可以通过指针进行间接修改
- const 常量修改
- C++之类内不同的数据成员类型以及方法(静态,const,引用,常量引用)
- 改善C#程序的50种方法 条款2:运行时常量(readonly)优于编译时常量(const)