1、 编译器处理方式不同
#define是一个宏定义命令,它是在预处理阶段就进行了替换;
const修饰的是一个编译时常量,它是在编译阶段处理的。
2、 类型和安全检查不同
#define定义的标识符仅仅是产生文本替换,不管内容是否正确;
const修饰的符号是一个具有类型的符号,编译器在编译时会对其做严格的检查。
3、书写方式不同
#define是一个预处理命令,结束时没有分号;
const定义常量是一个说明语句,以分号结束。
4、 存储方式不同
#define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内存。
const常量会在内存中分配(可以是堆中也可以是栈中)。
5、const 可以节省空间,避免不必要的内存分配。
例如:
#define PI 3.14159 //常量宏
const doulbe Pi=3.14159; //此时并未将Pi放入内存中 ……
double i=Pi; //此时为Pi分配内存,以后不再分配!
double I=PI; //编译期间进行宏替换,分配内存
double j=Pi; //没有内存分配
double J=PI; //再进行宏替换,又一次分配内存!
const定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在程序运行过程中只有一份拷贝,而 #define定义的常量在内存中有若干个拷贝。
6、作用域
#define定义的常量,尽管在某个函数内,但他的作用域是从定义开始,直到遇到#undef取消其定义为止,要是不取消,就会直到文件结束;
const定义的变量,要是在函数内,那么它的作用域就是它定义开始,到它所在的复合语句结束为止。
7、提高了效率。
编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高。
8、 调试
有些集成化的调试工具可以对const常量进行调试,但是不能对#define修饰的宏常量进行调试。