const内存分配

 

常量有没有存储空间,或者只是编译时的符号而已?

不一定。

在C中,define常量是预处理阶段的工作,其不占据内存。但是const常量总是占据内存

在C++中,const常量是否占据存储空间取决于是否有引用该常量地址的代码。C++对于const默认为内部链接,因此const常量定义通常都放在头文件中,即使分配内存也不会出现链接错误。

若不引用常量对应的地址,则不会为其分配空间。

 

Const是用来替换define的,因此其必须能够放在头文件中,在C++中const变量是默认为内部链接的,即在其他文件中看不到本文件定义的const变量,因此链接不会出现问题。Const变量在定义的时候必须初始化,除非显式的指定其为extern的。通常C++中会尽量避免为const变量分配内存storage的,而是在编译阶段将其保存在符号表symbol table中。当用extern修饰const变量或引用其地址时,将强制为其分配内存,因为extern表示采用外部链接,因此其必须有某个地址保存其值。

#include <iostream.h>

const int i=100;   //无法找到i的符号,因为没有为其分配存储空间。
const int j=i+100;   //强迫编译器为常量分配存储空间
long address=(long)&j;
char buf[j+10];
int main(int argc, char* argv[])
{
 const char c=cin.get();
 const char d=3;  // 局部变量栈区
 char test1[d+10];
 //char test2[c+10];  error const char c必须到运行时刻动态获取其初值。char test2[c+10]编译无法通过,因为无法确定c就无法确定数组长度。
 const char c2=c-'a'+'A';
 cout<<c<<" "<<c2<<endl;
 return 0;
}

你可能感兴趣的:(c,工作,table,存储,编译器)