1) 编译器处理方式不同

  define宏是在预处理阶段展开。

  const常量是编译运行阶段使用。

(2) 类型和安全检查不同

  define宏没有类型,不做任何类型检查,仅仅是展开。

  const常量有具体的类型,在编译阶段会执行类型检查。

(3) 存储方式不同

  define宏仅仅是展开,有多少地方使用,就展开多少次,不会分配内存。

  const常量会在内存中分配(可以是堆中也可以是栈中)。

(4)const  可以节省空间,避免不必要的内存分配。 例如:  
        #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定义常量从汇编的角度来看,只是给出了对应的内存地址,而不是象#define一样给出的是立即数,所以,const定义的常量在程序运行过程中只有一份拷贝,而 #define定义的常量在内存中有若干个拷贝。 
(5) 提高了效率。 编译器通常不为普通const常量分配存储空间,而是将它们保存在符号表中,这使得它成为一个编译期间的常量,没有了存储与读内存的操作,使得它的效率也很高。

const 与 #define的比较

C++ 语言可以用const来定义常量,也可以用 #define来定义常量。但是前者比后者有更多的优点:

(1)   const常量有数据类型,而宏常量没有数据类型。编译器可以对前者进行类型安全检查。而对后者只进行字符替换,没有类型安全检查,并且在字符替换可能会产生意料不到的错误(边际效应)。

(2)   有些集成化的调试工具可以对const常量进行调试,但是不能对宏常量进行调试。

l  【规则5-2-1】在C++ 程序中只使用const常量而不使用宏常量,即const常量完全取代宏常量。

5.3 常量定义规则

l  【规则5-3-1】需要对外公开的常量放在头文件中,不需要对外公开的常量放在定义文件的头部。为便于管理,可以把不同模块的常量集中存放在一个公共的头文件中。

l  【规则5-3-2】如果某一常量与其它常量密切相关,应在定义中包含这种关系,而不应给出一些孤立的值。

例如:

const  float   RADIUS = 100;

const  float   DIAMETER = RADIUS * 2;

5.4 类中的常量

有时我们希望某些常量只在类中有效。由于#define定义的宏常量是全局的,不能达到目的,于是想当然地觉得应该用const修饰数据成员来实现。const数据成员的确是存在的,但其含义却不是我们所期望的。const数据成员只在某个对象生存期内是常量,而对于整个类而言却是可变的,因为类可以创建多个对象,不同的对象其const数据成员的值可以不同。

不能在类声明中初始化const数据成员。以下用法是错误的,因为类的对象未被创建时,编译器不知道SIZE的值是什么。

class A

{…

const int SIZE = 100; // 错误,企图在类声明中初始化const数据成员

int array[SIZE];       // 错误,未知的SIZE

};

const数据成员的初始化只能在类构造函数的初始化表中进行,例如

class A

{…

A(int size);       // 构造函数

const int SIZE ;

};

A::A(int size) : SIZE(size) // 构造函数的初始化表

{

}

A  a(100);  // 对象 a 的SIZE值为100

A  b(200);  // 对象 b 的SIZE值为200

怎样才能建立在整个类中都恒定的常量呢?别指望const数据成员了,应该用类中的枚举常量来实现。例如

class A

{…

enum { SIZE1 = 100, SIZE2 = 200}; // 枚举常量

int array1[SIZE1];

int array2[SIZE2];

};

枚举常量不会占用对象的存储空间,它们在编译时被全部求值。枚举常量的缺点是:它的隐含数据类型是整数,其最大值有限,且不能表示浮点数(如PI=3.14159)。sizeof(A) = 1200;其中枚举部长空间。

enum   EM { SIZE1 = 100, SIZE2 = 200}; // 枚举常量    sizeof(EM) = 4;

const 和 #define区别相关推荐

  1. C语言 const 和 define 区别 - C语言零基础入门教程

    目录 一.const 使用 1.const 修饰变量 2.const 修饰指针 3.const 修饰在函数名前面 4.const 修饰在函数名后面 5.const 修饰函数参数 二.define 使用 ...

  2. C语言 const 和 define 区别

    一.const 使用 const是 constant 的缩写,"恒定不变"的意思.被 const 修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性.所以很多C++程 ...

  3. const和define 区别

    1: 编译器处理不同 define宏是在预处理阶段展开,const常量是编译运行阶段使用. 2:类型和安全检查不同 const常量有数据类型,而宏常量没有数据类型,仅仅是展开.编译器可以对前者进行类型 ...

  4. const 和 #define 区别总结

    const有类型,可进行编译器安全检查,#define 无类型,不可进行类型检查 const 有作用域,而#define 不重视作用域,默认定义在指定作用域下有效的常量,那么#define 就不能用( ...

  5. C和指针之const、#define、volatile

    1.const   定义const 只读变量,具有不可变形 const int a = 100; 编译器通常不为普通Const只读变量分配存储空间, 而是将它们保存在符号表中,   这使得它成为一个编 ...

  6. const与define相比优点_const与#define的区别、优点

    const与#define的区别 编译器处理方式不同 define宏是在预处理阶段展开. 补充:预处理器根据以#开头的命令,修改原始的程序.比如我们常见的#include 命令告诉处理器读取系统头文件 ...

  7. C++ 中 const和define的区别

    来源网址:http://wujiangping.blog.163.com/blog/static/195182011201255115125205/ 请区别用#define命令定义的符号常量和用con ...

  8. C++day01 const和define之间的区别

    大家好,我是阿林,一个c++的初学者.记录我学习c++的过程. 今天主要讲的是 const和define之间的区别 const和define都是定义常量,但是它们却有着定义域,作用域上的不同. def ...

  9. const int *,const int * const和int const *有什么区别?

    我总是搞砸了如何正确使用<code>const int* , const int * const和int const * . 是否有一组规则定义您可以做什么和不能做什么? 我想知道在分配, ...

最新文章

  1. hdu3966 树链剖分点权模板+线段树区间更新/树状数组区间更新单点查询
  2. Python之路【第七篇】:初识Socket
  3. 天梯赛2016-L2
  4. 一目了然,看民生银行 IT 运维故障管理可视化案例
  5. jquery解析php json,Jquery解析json数据详解_jquery
  6. py文件编译成pyc文件
  7. ThinkPad T43续命记
  8. 那缕清香,右手阑珊,左手寂寞
  9. Eclipse 下载带有WTP 相应插件板本的地址
  10. 贪心(优先队列) - New Year Snowmen - CodeForces - 140C
  11. VUE实战--网易云音乐
  12. 第二章:简单古典密码(及其五元组)
  13. 昆石VOS3000_2.1.6.0.0一键安装教程
  14. Single Channel Speech Enhancement Using Temporal Convolutional Recurrent Neural Networks
  15. 电化学工作站求峰高实现设计
  16. 韩钰带你一起走进电商世界之淘宝店铺设计尺寸规范
  17. xshell查看某个时间段的日志
  18. asp.net1044-学院宿舍报修信息系统#毕业设计
  19. 邮件TLS/SSL加密通信
  20. 决战私服与服务器不稳定,Droiyan online决战私服合区教程

热门文章

  1. 【数字信号处理】线性常系数差分方程 ( 根据 “ 线性常系数差分方程 “ 与 “ 边界条件 “ 确定系统是否是 “ 线性时不变系统 “ 案例 | 使用递推方法证明 )
  2. 【Groovy】json 序列化 ( JsonBuilder 生成器 | 生成带根节点名称的 json 字符串 | 生成不带根节点名称的 json 字符串 )
  3. 【Groovy】Gradle 构建工具 ( 自动下载并配置构建环境 | 提供 API 扩展与开发工具集成 | 内置 Maven 和 Ivy 依赖管理 | 使用 Groovy 编写构建脚本 )
  4. 【Flutter】Future 异步编程 ( 简介 | then 方法 | 异常捕获 | async、await 关键字 | whenComplete 方法 | timeout 方法 )
  5. 【Android 插件化】插件化简介 ( 组件化与插件化 )
  6. 【Cubase】Cubase 量化设置 ( 量化预置 | 长度量化 | 快捷键设置 | 量化开头 | 量化 MIDI 事件结尾 | 量化 MIDI 事件长度 )
  7. 【Netty】Netty 核心组件 ( Future | Channel | Selector | ChannelHandler )
  8. 【Java 网络编程】TCP 服务器端 客户端 简单示例
  9. 多校1010 Taotao Picks Apples
  10. 关于动态门户WEB博雅互动的源代码(HTML+CSS+javascript)