c语言中的const 常变量和 enum枚举和#define 符号量的 |
您所在的位置:网站首页 › 枚举变量占什么内存 › c语言中的const 常变量和 enum枚举和#define 符号量的 |
首先对于这三个我们在熟悉不过所以现在开始分析 注意全局的const和enum变量; 首先从存储位置上来说 #define只是单纯的符号替换并且在预处理阶段就进行,所以他所占的内存也只是代码段; 对于枚举变量而言和全局const常变量都是在只读数据段放着注意(const 变量没初始化只是在bss段放着可以指针修改内存) 具体而言const修饰的是常变量 emnu修饰的是枚举量都是在只读数据段他两都是实体,而define没有实体只是符号, 看一个代码 #include #include #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变量编译器进行替换;
|
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |