1.在C89标准下的const
const 修饰的类型是一个常变量,不能作为数组的下标。常变量不能作为左值。
如:
const int a = 10;
int b = a;
//其编译的过程和一般变量编译的过程相同
//并不会把引用符号的地方替换为对应的数据
2.C++99
(1)常量:在c++中,const int a = 10
是一个真真正正的常量。
(2)常变量:退化为常变量的情况,初始化为一个不明确的值。
(3)常变量和普通变量生成的符号的作用域不一样。
int a = 10;
const int b = a;//在编译阶段不会进行运算
对比下面两段代码,都是执行打印操作,但在本质上它们是有区别的。
//常变量
int a = 10;
const int b = a;
cout << b << endl;
mov eax,dword ptr[ebp-8]
push eax
//常量
const int b = 20;
cout << b << endl;
//cout其实也是函数调用,调用会压参数。
//汇编代码
push 20
测试常量和普通变量所生成符号的作用域:
#include<iostream>
using namespace std;
int a = 10;//普通全局变量
const int d = 20;//常量
int main()
{
return 0;
}
1.g++ test.cpp -c 生成test.o文件
2.使用readelf -s test.o命令查看编译之后生成的符号表。
由图可见,普通变量生成的符号为GLOBAL,而经过const修饰的常量生成的符号是LOCAL。所以普通变量和常量作用域是不相同的。
3.要访问另外一个文件中定义的常量的方法。
在定义处添加extern关键字,使其编程后生成的符号为GLOBAL,这样链接器就可以对其进行处理。
//简单的测试一下,方法同上
#include<iostream>
using namespace std;
extern const int a = 10;
int mian()
{
return 0;
}
//g++ test.cpp -c -o test.o
//readelf -s test.o
可以看到,经过extern
修饰的常量,进过编译生成的符号表中其作用域变为GLOBAL。