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 常量的语法个性