"const" & "#define"

来源:互联网 发布:淘宝物品怎么靠前搜到 编辑:程序博客网 时间:2024/06/14 00:35

"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,我们这样使用Nint a = N/2; //我们预想的a的值是2.5,可实际上a的值是3.5//原因在于在预处理阶段,编译器将 a = N/2处理成了 a = 2+3/2;这就是宏定义的字符串替换的“边缘效应”#define N (2+3)  //正确定义
  • 在大规模的开发过程中,特别是跨平台和系统的软件里,define最重要的功能是条件编译;

  • 除了定义常量外,const还有强大的修饰功能。#define 能增加程序的可读性,有些复杂的功能只需一条宏显示。
1 0
原创粉丝点击