C++ const 的周全总结   
               添加时间:2013-7-31 点击量: 
 
               C++中的const关键字的用法很是灵活,而应用const将大大改良法度的结实性,本人按照各方面查到的材料进行总结如下,期望对伴侣们有所帮助。 
Const 是C++中常用的类型润饰符,常类型是指应用类型润饰符const申明的类型,常类型的变量或对象的值是不克不及被更新的。 
No. 
感化 
申明 
参考代码 
1 
可以定义const常量 
const int Max = 100; 
2 
便于进行类型搜检 
const常量稀有据类型,而宏常量没稀有据类型。编译器可以对前者进行类型安然搜检,而对后者只进行字符调换,没有类型安然搜检,并且在字符调换时可能会产生料想不到的错误 
void f(const int i) { .........}
//对传入的参数进行类型搜检,不匹配进行提示 
3 
可以保护被润饰的器材 
防止不测的批改,加强法度的结实性。 
void f(const int i) { i=10;//error! }
//若是在函数体内批改了i,编译器就会报错 
4 
可以很便利地进行参数的调剂和批改 
同宏定义一样,可以做到不变则已,一变都变 
5 
为函数重载供给了一个参考 
class A
{
......
void f(int i) {......} //一个函数
void f(int i) const {......} //上一个函数的重载
......
}; 
6 
可以节俭空间,避免不须要的内存分派 
const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在法度运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝 
#define PI 3.14159 //常量宏
const doulbe Pi=3.14159; //此时并未将Pi放入ROM中
......
double i=Pi; //此时为Pi分派内存,今后不再分派!
double I=PI; //编译时代进行宏调换,分派内存
double j=Pi; //没有内存分派
double J=PI; //再进行宏调换,又一次分派内存! 
7 
进步了效力 
编译器凡是不为通俗const常量分派存储空间,而是将它们保存在符号表中,这使得它成为一个编译时代的常量,没有了存储与读内存的操纵,使得它的效力也很高 
int const p =&a; //等价const int p =&a;   //指针所指值是常量 , p可以批改
int  const p ;   //指针是常量,所指向的值可以批改
 
class WORK
{
public:
     const int NUM;
    int a;
    WORK():NUM(3)   //const var must init in init_list
    {
        a=1;
    }
    void change()
    {
        a =2;
    }
    void disp()const
    {
        cout<<const NUM=<<NUM<<endl;
        //change();  //const function can not call non_function
        //a=3;  const function can not modify member variable
    }
};
我俩之间有着强烈的吸引力。短短几个小时后,我俩已经明白:我们的心是一个整体的两半,我俩的心灵是孪生兄妹,是知己。她让我感到更有活力,更完美,更幸福。即使她不在我身边,我依然还是感到幸福,因为她总是以这样或者那样的方式出现在我心头。——恩里克·巴里奥斯《爱的文明》
                     
                  
     
  
 
    
    
C++中的const关键字的用法很是灵活,而应用const将大大改良法度的结实性,本人按照各方面查到的材料进行总结如下,期望对伴侣们有所帮助。
Const 是C++中常用的类型润饰符,常类型是指应用类型润饰符const申明的类型,常类型的变量或对象的值是不克不及被更新的。
No.
感化
申明
参考代码
1
可以定义const常量
const int Max = 100;
2
便于进行类型搜检
const常量稀有据类型,而宏常量没稀有据类型。编译器可以对前者进行类型安然搜检,而对后者只进行字符调换,没有类型安然搜检,并且在字符调换时可能会产生料想不到的错误
void f(const int i) { .........}
//对传入的参数进行类型搜检,不匹配进行提示 
3
可以保护被润饰的器材
防止不测的批改,加强法度的结实性。
void f(const int i) { i=10;//error! }
//若是在函数体内批改了i,编译器就会报错 
4
可以很便利地进行参数的调剂和批改
同宏定义一样,可以做到不变则已,一变都变
5
为函数重载供给了一个参考
class A
{
......
void f(int i) {......} //一个函数
void f(int i) const {......} //上一个函数的重载
......
}; 
6
可以节俭空间,避免不须要的内存分派
const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在法度运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝
#define PI 3.14159 //常量宏
const doulbe Pi=3.14159; //此时并未将Pi放入ROM中
......
double i=Pi; //此时为Pi分派内存,今后不再分派!
double I=PI; //编译时代进行宏调换,分派内存
double j=Pi; //没有内存分派
double J=PI; //再进行宏调换,又一次分派内存! 
7
进步了效力
编译器凡是不为通俗const常量分派存储空间,而是将它们保存在符号表中,这使得它成为一个编译时代的常量,没有了存储与读内存的操纵,使得它的效力也很高
int const p =&a; //等价const int p =&a; //指针所指值是常量 , p可以批改
int const p ; //指针是常量,所指向的值可以批改
class WORK
{
public:
const int NUM;
int a;
WORK():NUM(3) //const var must init in init_list
{
a=1;
}
void change()
{
a =2;
}
void disp()const
{
cout<<const NUM=<<NUM<<endl;
//change(); //const function can not call non_function
//a=3; const function can not modify member variable
}
};




