C语言中的const
const润饰的变量是只读的,实质还是变量
const润饰的局部变量在栈上调配空间
const润饰的全局变量在只读存储区调配空间
const只在编译器有用,再运行期无用
const润饰的变量不是真的变量,只是通知编译器该变量不能呈现再赋值符号的右边
const使得变量只有只读属性
const将具备全局生命周期的变量存在只读存储区
const不是真正意义上的常量,只有枚举是真正意义的常量
C编译器:
#include"stdio.h"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; }
输入后果:
Begin...
c = 5
End...
C++编译器:
#include"stdio.h"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; }
输入后果:
Begin...
c = 0
End...
C++中的const
C++在C的根底上对const进行了进化解决
当碰见const申明时在符号表中放入常量
编译过程中若发现应用常量则间接以符号表中的值替换
编译过程中若发现下述状况给对应的常量调配存储空间
对const常量应用了extern
对const常量应用&操作符
C++编译器尽管可能为const常量调配空间,但不会应用其存储空间中的值。
C语言中的const变量
C语言中const变量是只读变量,会调配存储空间
C++中的const常量
-可能调配存储空间
当const常量全局,并且须要在其余文件中应用
当应用&操作符对const常量取地址
C++中const常量相似于宏定义
const int c = 5; ≈#define c 5
C++中的const常量在宏定义中不同
const常量是由编译器解决
编译器对const常量进行类型检查和作用域查看
宏定义由预处理器解决,单纯的文本替换
#include "stdio.h"void f(){ #define a 3 const int b = 4;}void g(){ printf("a=%d\n",a);}int main(){ const int A = 1; const int B = 2; int array[A+B] = {0}; int i = 0; for(i = 0;i<(A+B);i++) { printf("array[%d] = %d\n",i,array[i]); } f(); g(); return 0;}
小结
与C语言不同,C++中的const不是只读变量
C++中的const是一个真正意义上的常量
C++编译器可能会为const常量调配空间
C++齐全兼容C语言中的const常量的语法个性