"const" & "#define"

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

  • 除了定义常量外,const还有强大的修饰功能。#define 能增加程序的可读性,有些复杂的功能只需一条宏显示。
  • 2
    点赞
  • 1
    收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
评论

打赏作者

Donny-You

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值