第3课 进化后的 const分析

时间:2024-01-09 15:44:32

1.  C语言中的const

(1)const修饰的变量是只读的,使得变量具有只读属性,但本质还是变量。所以不是真正的常量,它只是告诉编译器该变量不能出现在赋值符号的左边。

(2)const修饰的局部变量栈上分配空间全局变量只读存储区分配空间

(3)const只在编译期有用,在运行期无用

【编程实验】C/C++中的const

#include <stdio.h>

int main()
{
const int c = ; //C语言中会为变量c分配内存
int* p = (int*)&c; //C++中遇到&才为c分配内存 printf("Begin...\n"); *p = ; //内存中的值己被改为5. printf("c = %d\n", c);//C语言会输出内存中的5.
//C++中会从符号表(而不是内存)中取值
//所以为0. printf("End...\n");
return ;
}

2. C++中的const

(1)C++在C的基础上对const进行了优先处理,当碰见const声明时在符号表中放入常量。

(2)编译过程中若发现使用常量,则直接以符号表中的值替换

第3课 进化后的 const分析

(3)编译过程中若发现对const常量使用了extern&操作符,则会给对应的常量分配存储空间。注意,C++编译器虽然可能为const常量分配空间,但不会使用其存储空间中的值。

3. 对比C/C++中的const

C语言

C++

本质

只读变量

常量

分配内存

会分配

当使用&操作符对const常量取地址时分配

当const常量为全局,并且需要在其它文件中使用时会分配内存

4. C++中的const与宏的区别

C++中的const

定义

const int c = 5;

#define c 5

处理方式

编译器处理,编译器会进行类型检查作用域检查

预处理器处理,只是简单的文本替换

【编程实验】const与宏

#include <stdio.h>

void f()
{
//宏由预编译处理,其后面的宏起作用
#define a 3 const int b = ;//作用域仅限于f函数
} void g()
{
printf("a = %d\n", a); //合法,只要是宏定义之后都可以使用 //printf("b = %d\n", b); //非法b的作用域仅限于f函数
} int main()
{
const int A = ;
const int B = ;
int array[A + B] = {};//C++中合法,因为它认为A、B都是常量。
//而C语言的const本质还是变量,数组大小只能是常量 int i = ; for(i=;i<(A + B); i++)
{
printf("array[%d] = %d\n", i, array[i]);
} f();
g(); return ;
}

5. 小结

(1)与C语言不同,C++中的const不是只读变量

(2)C++中的const是一个真正意义上的常量

(3)C++编译器可能会为const常量分配空间

(4)C++完全兼容C语言中的const常量的语法特性