首先对于这三个我们在熟悉不过所以现在开始分析
注意全局的const和enum变量;
首先从存储位置上来说 #define只是单纯的符号替换并且在预处理阶段就进行,所以他所占的内存也只是代码段;
对于枚举变量而言和全局const常变量都是在只读数据段放着注意(const 变量没初始化只是在bss段放着可以指针修改内存)
具体而言const修饰的是常变量 emnu修饰的是枚举量都是在只读数据段他两都是实体,而define没有实体只是符号,
看一个代码
#include <stdio.h>
#include <assert.h>
#define MIN 0
enum
{
MAX,
};
const int MAX1=0;
int main()
{
int i = 1;
int x = MAX;
x = MIN;
x = MAX1;
return 0;
}
反汇编代码如下
int x = MAX;
002613A5 mov dword ptr [x],0
x = MIN;
002613AC mov dword ptr [x],0
x = MAX1;
002613B3 mov eax,dword ptr ds:[00265858h]
002613B8 mov dword ptr [x],eax
return 0;
分析对于枚举变量而言他是在编译时期由编译器进行替换的而const修饰的 常变量是从内存中取出来,在赋值,
对比而言程序运行时枚举和define一样快而const修饰的变量是最慢的
在分析对于const和emun而言都是有类型的emun是整形const修饰的变量也有自己的类型但是define没有自己的类型
所以相比而言cosnt和emun有类型检查的问题而define没有容易造成一些问题;
并且emun的优势也很明显虽但是在实际使用中emnu可以限制用户的输入,可同时定义多个相关的枚举常量,进行使用
在使用上而言
define定义需要给值const变量也要初始化而emun变量编译器进行替换;