C++中的const正常情况下是看成编译期的常量,编译器并不为const分配空间,只是在编译的时候将期值保存在名字表中,并在适当的时候折合在代码中.所以,以下代码: #include using namespace std; int main() { const int a = 1; const int b = 2; int array[ a + b ] = {0}; for (int i = 0; i < sizeof array / sizeof *array; i++) { cout << array[i] << endl; } } 在可以通过编译,并且正常运行.但稍加修改后,放在C编译器中,便会出现错误: #include int main() { int i; const int a = 1; const int b = 2; int array[ a + b ] = {0}; for (i = 0; i < sizeof array / sizeof *array; i++) { printf("%d",array[i]); } } 错误消息: c:\test1\te.c(8): error C2057: 应输入常数表达式 c:\test1\te.c(8): error C2466: 不能分配常数大小为 0 的数组 出现这种情况的原因是: 在C中,const是一个不能被改变的普通变量,既然是变量,就要占用存储空间,所以编译器不知道编译时的值.而且,数组定义时的下标必须为常量. 在C语言中: const int size; 这个语句是正确的,因为它被C编译器看作一个声明,指明在别的地方分配存储空间.但在C++中这样写是不正确的.C++中const默认是内部连接,如果想在C++中达到以上的效果,必须要用extern关键字.
C++中,const默认使用内部连接.而C中使用外部连接. 内连接:编译器只对正被编译的文件创建存储空间,别的文件可以使用相同的表示符 或全局变量.C/C++中内连接使用static关键字指定. 外连接:所有被编译过的文件创建一片单独存储空间.一旦空间被创建,连接器必须解 决对这片存储空间的引用.全局变量和函数使用外部连接.通过extern关键 字声明,可以从其他文件访问相应的变量和函数. ************************C++代码****************************** header.h const int test = 1; test1.cpp #include #include "header.h" using namespace std; int main() { cout << "in test1 :" << test << endl; } test2.cpp #include #include "header.h" using namespace std; void print() { cout << "in test2:" << test << endl; } 以上代码编译连接完全不会出问题,但如果把header.h改为: extern const int test = 1; 在连接的时候,便会出现以下错误信息: test2 error LNK2005: "int const test" () 已经在 test1.obj 中定义 因为extern关键字告诉C++编译器test会在其他地方引用,所以,C++编译器就会为test创建存储空间,不再是简单的存储在名字表里面.所以,当两个文件同时包含header.h的时候,会发生名字上的冲突. 此种情况和C中const含义相似: header.h const int test = 1; test1.c #include #include "header.h" int main() { printf("in test1:%d\n",test); } test2.c #include #include "header.h" void print() { printf("in test2:%d\n",test); } 错误消息: test3 fatal error LNK1169: 找到一个或多个多重定义的符号 test3 error LNK2005: _test 已经在 test1.obj 中定义