C语言中的const和C++中的const区别及使用介绍
C语言中的const
const 修饰的变量是只读的,本质还是变量 const 修饰的局部变量在栈上分配空间 const 修饰的全局变量在只读存储区分配空间 const 只在编译期有用,在运行期无用
const修饰的变量不是真的常量,它只是告诉编译器该变量不能出现在赋值符号的左边
C语言中的const使得变量具有只读属性 const将具有全局生命周期的变量存储于只读存储区
const 不能定义真正意义上常量
#include int main() { const int c = 0; int *p = (int *)&c; printf("Begin...\n"); *p = 5; printf("c = %d\n",c); printf("End...\n"); return 0; }
编译结果
gcc test.c –> c = 5 g++ test.cpp –> c = 0
C++中的const
C++在C的基础上对const进行了进化处理 当碰见 const 声明时在符号表中放入常量 编译过程中若发现使用常量则直接以符号表中值替换 编译过程中若发现下述情况则给对应的常量分配存储空间
对const 常量使用了extern 对const 常量使用& 操作符
注意: C++编译器虽然可能为const常量分配空间,但不会使用其存储空间的值
图1解释 test.cpp 中的c = 0的原因
区别
C语言中的const 变量
C语言中const 变量是只读变量,会分配存储空间
C++中的const 常量
可能分配存储空间
当const 常量为全局,并且需要在其它文件中使用 当使用&操作符对const常量取地址 C++中的const 常量类似于宏定义
const int c = 5; ≈ #define c 5 C++ 中的const 常量在与宏定义不同
const 常量是由编译器处理 编译器对const常量进行类型检查和作用域检查 宏定义由预处理器处理,单纯的文本替换
小结
与C语言不同,C++中的const不是只读变量 C++中的const是一个真正意义上的常量 C++编译器可能会为const常量分配空间 C++完全兼容C语言中const常量的语法特性
下一篇: SQLite3源码学习之链表的归并排序
推荐阅读
-
在C++中,函数名前的const和函数名后的const的区别详解
-
C++中static_cast/const_cast/dynamic_cast/reinterpret_cast的区别和使用
-
C语言中的const和C++中的const区别及使用介绍
-
C++和C中const的区别详解
-
在C++中,函数名前的const和函数名后的const的区别详解
-
C++中static_cast/const_cast/dynamic_cast/reinterpret_cast的区别和使用
-
JavaScript中let、var和const的区别及应用场景的介绍
-
c与c++中const和static的区别介绍
-
C语言中的const和C++中的const区别及使用介绍
-
JavaScript中let、var和const的区别及应用场景的介绍