const定义的只读变量在程序运行过程中只有一份拷贝(因为它是全局的只读变量,存放在静态区),而#define定义的宏常量在内存中有若干个拷贝。 #define宏是在预编译阶段进行替换,而const修饰的只读变量是在编译的时候确定其值。 #define宏没有类型,而const修饰的只读变量具有特定的类型 =========================================== const int *p; //p可变,p指向的对象不可变 int const*p; //p可变,p指向的对象不可变 int *const p; //p不可变,p指向的对象可变 const int *const p; //指针p和p指向的对象都不可变 ==================================== 总的来说: const:有数据类型,编译进行安全检查,可调试 define:宏,不考虑数据类型,没有安检,不能调试 ================================ 这里有一个记忆和理解的方法: 先忽略类型名(编译器解析的时候也是忽略类型名),我们看const离哪个近。"近水楼台先得月",离谁近就修饰谁。 判断时忽略括号中的类型 const (int) *p; //const修饰*p,*p是指针指向的对象,不可变 (int) const *p; //const修饰*p,*p是指针指向的对象,不可变 (int)*const p; //const修饰p,p不可变,p指向的对象可变 const (int) *const p; //前一个const修饰*p,后一个const修饰p,指针p和p指向的对象都不可变
define宏是在预处理阶段展开。
const常量是编译运行阶段使用。
(2) 类型和安全检查不同
define宏没有类型,不做任何类型检查,仅仅是展开。
const常量有具体的类型,在编译阶段会执行类型检查。
(3) 存储方式不同
define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内存。