在C语言中关于const修饰的变量:
- ??C语言中const修饰的变量叫常变量,不叫常量
- ??C语言中的常变量之所以叫做常变量是因为不能作为左值使用,其余与变量无异,也就是是说常变量的值可以被修改
- ??常变量可以不初始化,但是如果不初始化,那么之后也就没有办法直接赋值,需要通过指针进行赋值
先来看一段代码:
const int a = 20; //常变量
int* p = (int*)&a;
*p = 30;
//a是常变量,不能作为左值外,本质上还是一个变量,所以可以通过指针进行值的修改
printf("%d %d %d\n", a, *p, *(&a)); //输出30 30 30
//不初始化
const int b;
int* pb = (int*)&b;
*pb = 100;
printf("%d %d\n", b, *pb); //输出100 100
return 0;
?你们认为这一段代码运行的结果会是什么??
运行结果:
我们再来看C++中const修饰的变量
- ?C++中const修饰的变量叫做常量,必须初始化,不能作为左值使用
- ?C++中const编译的方式和C语言不同,C语言中const适当做一个变量来编译生成指令的;C++中所有出现const常量名字的地方,都被常量的初始化替换了?? ?test01();
- ?C++中const修饰的变量虽然叫常量,但是依然可以通过指针对其值进行修改?
再来看这一段代码:
void test01()
{
const int a = 20; //常量
int* p = (int*)&a;
*p = 30;
cout << a << " " << *p << " " << *(&a) << endl; //输出20 30 20
}
?运行之后会输出什么呢???
输出20? 30? 20, 在编译这段代码时,代码中所有出现const修饰的变量名字的地方都会被直接替换成了初始值,也就是20。利用指针对a的值进行修改,a的值被改成了30,通过指针的解引用可以找到那块内存区域的值被改成了30;
那再来看另外一个
使用一个变量来初始化const修饰的变量,那这个变量不再是常量,而是常变量
代码段
void test02()
{
int a = 20;
const int b = a; //常变量
int* p = (int*)&b;
*p = 30;
cout << b << " " << *p << " " << *(&b) << endl;
}
?那运行结果肯定就是和C语言一样得了。
?
|