"const" & "#define" 在C和C++中的定义
- C++并非使用const取代#define,而只是增加了const。在C++程序中只使用const常量而不使用宏常量,即const常量完全取代宏常量;
- C99的标准增加了const的关键字,即现在const并非C++专有,在C语言中也可以使用const代替#define定义一些常量,为了考虑兼容那些没有实现const编译器的要求,在C中可以考虑不使用const;
- const是c++中的修饰符,c++中常用来定义常量,修饰左值,对数据进行类型检查;#define为宏定义语句, 在预处理阶段直接做文本替换,不做类型检查。有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。
"const" & "#define" 的具体区别
- 编译器处理方式不同:#define宏是在预处理阶段展开,const常量是编译运行阶段使用;
- 类型和安全检查不同:#define宏没有类型,不做任何类型检查,仅仅是展开,const常量有具体的类型,在编译阶段会执行类型检查;
- 存储方式不同:#define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内存,const常量会在内存中分配(可以是堆中也可以是栈中);
- const 可以节省空间,避免不必要的内存分配,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; //再进行宏替换,又一次分配内存!
- const提高了效率。编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高;
- define定义表达式时要注意“边缘效应”,例如如下定义:
#define N 2+3 //我们预想的N值是5,我们这样使用N int a = N/2; //我们预想的a的值是2.5,可实际上a的值是3.5 //原因在于在预处理阶段,编译器将 a = N/2处理成了 a = 2+3/2;这就是宏定义的字符串替换的“边缘效应” #define N (2+3) //正确定义
-
在大规模的开发过程中,特别是跨平台和系统的软件里,define最重要的功能是条件编译;
- 除了定义常量外,const还有强大的修饰功能。#define 能增加程序的可读性,有些复杂的功能只需一条宏显示。