#include <iostream>
using namespace std;
int main1() {
cout << "test" << endl;
// 两者相等
const int c1 = 1;
int const c2 = 2;
cout << "c1:" << c1 << ';' << "c2:" << c2 << endl;
// cp1是指向 const 对象的指针,指向地址中的内容不能变,能指向另一个内存地址,
//*********** 等同与 int const *cp1; *************
const int *cp1; //const修饰的是整个 *cp1 ,实际上时 *cp1 是不变的,即指向的地址中的内容
cout << "cp1:" << cp1 << '\n'; //cp1 是一个内存地址
cout << "*cp1 intialize :" << *cp1 << endl;//*cp1 是cp指向的内存中的值
//*cp1 = 4; //错误信息:向只读位置‘* cp1’赋值,
//不能使用指向const对象的指针 *cp1 修改对象,但是可以通过其他方法改变指向的对象。
//如果想要改变指向的内容,可以30行代码:cp1 = &nonc_val;指向一个非const对象
//给 nonc_val = 11;重新赋值,*cp 随之改变。
//所以说 int const *cp; cp指向的对象不变,是不全面的。
const int c_val =1;
//cp1可以在任意时候重新赋值一个新内存地址
cp1 = &c_val;//*cp1 可以指向另一块内存(存储 c_val = 4的地方)
cout << "*cp1-->c_val:" << *cp1 << '\n';
int nonc_val = 10;
cp1 = &nonc_val; //允许将非const类型的 val 赋值给const指针类型的cp1_val
cout << "执行 cp1 = &nonc_val后,*cp1-->nonc_val:" << *cp1 << '\n';
nonc_val = 11; //非const类型的可以改变值,
//*********这里不能用 *cp1 = 11; **********
cout << "执行 nonc_val = 11 后,*cp1-->nonc_val:" << *cp1 << '\n';
//******* int *const cp2;//const 修饰的时cp2,即指针不变*********
//cp2是指向对象的 const 指针,指向的内存地址不能变,但是其中的内容可以变
// 不能指向其他对象,可以修改对象的值
int i = 1;
int *const cp2 = &i; //必须初始化
cout << "cp2-->i:" << *cp2 << '\n';
*cp2 = 10;
cout << "执行 *cp2 = 10后,*cp2:" << *cp2 << '\n';
*cp2 = 11;
cout << "执行 *cp2 = 11后,*cp2:" << *cp2 << '\n';
//int j = 1;
//cp2 = &j; // 错误: 向只读变量‘cp2’赋值
return 0;
}
const * 和 * const 代码讲解
最新推荐文章于 2023-03-26 23:12:22 发布