No. | 作用 | 说明 | 参考代码 |
1 | 可以定义const常量 |
| const int Max = 100; |
2 | 便于进行类型检查 | const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查,而对后者只进行字符替换,没有类型安全检查,并且在字符替换时可能会产生意料不到的错误 | void f(const int i) { .........} |
3 | 可以保护被修饰的东西 | 防止意外的修改,增强程序的健壮性。 | void f(const int i) { i=10;//error! } |
4 | 可以很方便地进行参数的调整和修改 | 同宏定义一样,可以做到不变则已,一变都变 |
|
5 | 为函数重载提供了一个参考 |
| class A |
6 | 可以节省空间,避免不必要的内存分配 | const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在程序运行过程中只有一份拷贝,而#define定义的常量在内存中有若干个拷贝 | #define PI 3.14159 //常量宏 |
7 | 提高了效率 | 编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高 |
|