3. const 关键字分析
C语言中的 const
const
修饰的变量是只读的,本质还是变量const
修饰的局部变量在栈上分配空间const
修饰的全局变量在只读存储区分配空间const
只在编译期有用,在运行期无用
Tips:
const
修饰的变量不是真正的常量,它只是告诉编译器该变量不能出现在赋值符号的左边。
- C语言中的
const
使得变量具有只读属性 const
将具有全局生命周期的变量存储于只读存储区
Tips:
const
不能定义真正意义上的常量!!!
#include <stdio.h>
int main()
{
const int c = 0;
int* p = (int*)&c;
printf("Begin...\n");
*p = 5;
printf("c = %d\n", c);
printf("*p = %d\n", *p);
printf("End...\n");
return 0;
}
gun gcc 编译运行
编译:
gcc 3-1.c -o 3-1.out
运行:
./3-1.out
Begin...
c = 5
*p = 5
End...
gun g++ 编译运行
编译:
g++ 3-1.c -o 3-1.out
运行:
./3-1.out
Begin...
c = 0
*p = 5
End...
C++中的 const
- C++在C的基础上对
const
进行了进化处理- 当碰见
const
声明时在符号表中放入常量 - 编译过程中若发现使用常量则直接以符号表中的值替换
- 编译过程中若发现下述情况则给对应的常量分配存储空间
- 对
const
常量使用了extern
- 对
const
常量使用&
操作符
- 对
- 当碰见
注意:
C++编译器虽然可能为
const
常量分配空间,但不会使用其存储空间中的值
-
C语言中的
const
变量- C语言中
const
变量是只读变量,会分配存储空间
- C语言中
-
C++中的
const
常量- 可能分配存储空间
- 当
const
常量为全局,并且需要在其它文件中使用 - 当使用
&
操作符对const
常量取地址
- 当
- 可能分配存储空间
-
C++中的
const
常量类似于宏定义const int c = 5;
==>#define c 5
-
C++中的
const
常量与宏定义不同const
常量是由编译器处理- 编译器对
const
常量进行类型检查和作用域检查 - 宏定义由预处理器处理,单纯的文本替换
#include <stdio.h>
void f()
{
#define a 3
const int b = 4;
}
void g()
{
printf("a = %d\n", a);
// printf("b = %d\n", b); //error: ‘b’ was not declared in this scope
}
int main()
{
const int A = 1;
const int B = 2;
int array[A + B] = {0};
for (int i = 0; i < (A + B); i++)
{
printf("array[%d] = %d\n", i, array[i]);
}
f();
g();
return 0;
}
gun gcc 编译运行
编译:
gcc 3-2.c -o 3-2.out
3-2.c: In function ‘main’:
3-2.c:19:5: error: variable-sized object may not be initialized
19 | int array[A+B] = {0};
| ^~~
gun g++ 编译运行
编译:
g++ 3-2.c -o 3-2.out
运行:
./3-2.out
array[0] = 0
array[1] = 0
array[2] = 0
a = 3
小结:
- 与C语言不同,C++中的
const
不是只读变量 - C++中的
const
是一个真正意义上的常量 - C++编译器可能会为
const
常量分配空间 - C++完全兼容C语言中
const
常量的语法特性