C和C++中经const修饰的常量、常变量和普通变量的区别

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

猜你喜欢

转载自blog.csdn.net/asjbfjsb/article/details/80291212
今日推荐