博客
关于我
const和define区别与比较
阅读量:244 次
发布时间:2019-03-01

本文共 508 字,大约阅读时间需要 1 分钟。

(1)就起作用的阶段而言: #define主要在预处理阶段起作用,而const则在编译和运行时起作用。

(2)就起作用的方式而言: #define只是简单的字符替换,没有类型检查,存在边界错误;而const对应数据类型,进行类型检查,提供更高的安全性。

(3)就存储方式而言: #define展开后,替换次数等于使用次数,定义的宏常量在内存中有若干备份,占用代码段空间;而const定义的只读变量在程序运行过程中只有一份备份,占用数据段空间。

(4)从代码调试的方便程度而言: const常量支持调试,而#define在预编译阶段就已经替换,无法调试。

(5)从是否可以重定义的角度而言: const不能重定义,而#define可以通过#undef取消原定义,再重新定义。

(6)从特殊功能来看: #define可以用来防止头文件重复引用,而const不具备此功能。

(7)从类成员变量的定义来看: const用于类成员变量,只能在定义时指定类型,且不可修改;而#define不能用于类成员变量的定义,但可以用于全局变量。

(8)就名称选择方面: const采用普通常量名称,而#define可以使用表达式作为名称。

转载地址:http://uwpv.baihongyu.com/

你可能感兴趣的文章
npm安装crypto-js 如何安装crypto-js, python爬虫安装加解密插件 找不到模块crypto-js python报错解决丢失crypto-js模块
查看>>
npm安装教程
查看>>
npm报错Cannot find module ‘webpack‘ Require stack
查看>>
npm报错Failed at the node-sass@4.14.1 postinstall script
查看>>
npm报错fatal: Could not read from remote repository
查看>>
npm报错File to import not found or unreadable: @/assets/styles/global.scss.
查看>>
npm报错TypeError: this.getOptions is not a function
查看>>
npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
查看>>
npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
查看>>
npm版本过高问题
查看>>
npm的“--force“和“--legacy-peer-deps“参数
查看>>
npm的安装和更新---npm工作笔记002
查看>>
npm的常用操作---npm工作笔记003
查看>>
npm的常用配置项---npm工作笔记004
查看>>
npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
查看>>
npm编译报错You may need an additional loader to handle the result of these loaders
查看>>
npm设置淘宝镜像、升级等
查看>>
npm设置源地址,npm官方地址
查看>>
npm设置镜像如淘宝:http://npm.taobao.org/
查看>>
npm配置安装最新淘宝镜像,旧镜像会errror
查看>>