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
}
};