1、在C语言中,我们认为const是常变量,不可修改
下面这个代码在 .c 文件中是可以运行的,他把const所修饰的变量看作是常变量。
int main()
{
const int a = 10;
int* p = &a;
*p = 20;
printf("%d\n", a);
return 0;
}
C语言中,const用法**:C语言只是在编译阶段看一下const是否做左值**,如果做左值会报错;如果没有做左值,就视为变量处理。
2、在 .cpp 文件上运行上面的代码,程序会报错。
C++中,const的用法:在C++中,const修饰的变量称为常量。
3、C++中,const的特点:
(1)一定要初始化
int main()
{
const int a = 10;
int* p = (int*)&a;
*p = 20;
cout << "a:" << a << endl;
return 0;
}
运行结果为:10;为什么???
C++是在编译阶段,把用到的常量的地方换成了常量初始化的数值。
(2)杜绝间接访问来修改常量内存的风险
在76行,程序报错,因为程序会预感到你要修改常量,所以为了杜绝这种情况带来的风险,程序就会报错。
如果将76行改成const int* p = &a;
,此时const修饰的是 *p ,但是修改后77行就会报错,因为const修饰的变量不能做左值。
4、const与指针的结合
int a = 10;
int* p = &a;
int* q = p;
代码图解:
(1)在C语言中,我们是这样理解的:
const int*
看作小权限 ;int*
看作大权限
如果int*
==》const int*
,称为权限缩小,是可以执行的。
如果const int*
==》int*
,称为权限扩大,是不可以执行的。
我们看下列代码:
- error,第二行
const int*
==》int*
权限扩大,所以错误
const int a = 10;
int* p = &a;
int* q = p;
- error,第三行
const int*
==》int*
权限扩大,所以错误
int a = 10;
const int* p = &a;
int* q = p;
- error,第三行
int const*
==》int*
权限扩大,所以错误,但这只是我们的理解,运行发现,这段程序是运行成功的,因为系统认为p是int*类型,const没有参与类型
int a = 10;
int* const p = &a;
int* q = p;
所以对于C语言对const的理解是有bug的,我们用C++来看。
(1)在C++中,我们是这样理解的:
对于这个代码,我们认为const直接访问的是 a,间接访问(在直接访问的基础上高一级别的指向)的是 *p、*q
const int a = 10;
int* p = &a;
int* q = p;
因为C++中const会杜绝间接访问来修改常量内存的风险,所以要修改所有程序杜绝的问题,让const不要出现间接访问的。
修改为:
const int a = 10;
const int* p = &a;
const int* q = p;
(2)const直接访问的是 *p、a(因为p指向了a的地址),间接访问的是 *q
int a = 10;
const int* p = &a;
int* q = p;
所以修改为
int a = 10;
const int* p = &a;
const int* q = p;
(3)const直接访问的是 p,无间接访问,所以运行成功
int a = 10;
int* const p = &a;
int* q = p;