C++面试,说明const和#define的特点和区别

#define只是用来做文本替换的,例如:

cpp 复制代码
#define PI 3.1415926
float angel;
angel = 30 * PI /180;

当程序进行编译的时候。编译器会首先将"#define PI 3.1415926"以后所有代码中的PI都替换成3.1415926,然后进行编译。它的生命周期止于编译期,它存在于程序的代码段,在实际程序中它只是一个常数,一个命令中的参数,并没有实际的存在。

const常量存在于程序的数据段,并且在堆栈分配了空间。const常量有数据类型,但是宏却没有,编译器可以对const常量进行类型的安全检查。

相关推荐
眠りたいです35 分钟前
基于脚手架微服务的视频点播系统-服务端开发部分(补充)文件子服务问题修正
c++·微服务·云原生·架构
PineappleCoder41 分钟前
WebP/AVIF 有多香?比 JPEG 小 30%,<picture>标签完美解决兼容性
前端·面试·性能优化
ULTRA??1 小时前
各种排序算法时间复杂度分析和实现和优势
c++·python·算法·排序算法
博语小屋1 小时前
简单线程池实现(单例模式)
linux·开发语言·c++·单例模式
墨雪不会编程1 小时前
C++基础语法篇八 ——【类型转换、再探构造、友元】
java·开发语言·c++
yuuki2332331 小时前
【C++】内存管理
java·c++·算法
刃神太酷啦1 小时前
Linux 进程核心原理精讲:从体系结构到实战操作(含 fork / 状态 / 优先级)----《Hello Linux!》(6)
java·linux·运维·c语言·c++·算法·leetcode
一个不知名程序员www1 小时前
算法学习入门---二叉树
c++·算法
玩具猴_wjh1 小时前
面试问题相关回答
面试·职场和发展
小李小李快乐不已1 小时前
数组&&矩阵理论基础
数据结构·c++·线性代数·算法·leetcode·矩阵