1.c++类中定义const成员的时候必须进行初始化,而且只能通过初始化列表来进行 所以说类中存在const成员时,必须存在构造函数。当类中同时存在拷贝构造函数时也必须通过初始化列表将其初始化,否则编译器会报错
2.c++类中提供的const成员变量为只读变量,所以说我们可以通过一定的方式改变它
那么我们可以通过什么方式来改变cons成员呢?
2.c++类中提供的const成员变量为只读变量,所以说我们可以通过一定的方式改变它
那么我们可以通过什么方式来改变cons成员呢?
1.C++ 中提供了const_cast强制性类型转换符,用来将const的属性去掉,使用方法:const_cast<Tppe>(expression)
#include <stdio.h>
class Test
{
private:
int mi;
const int mj;
public:
const int mk;//只读变量
Test(int i);
Test(const Test& t);
int getMi();
void setmj(int p);
int getmj();
};
Test::Test(int i):mj(0),mk(1)
{
mi = i;
}
Test::Test(const Test& t):mj(0),mk(1)//拷贝构造函数存在时必须进行初始化
{
}
int Test::getMi()
{
return mi;
}
void Test::setmj(int p)
{
const_cast<int&>(mj) = p;
}
int Test::getmj()
{
return mj;
}
int main()
{
Test t(1);
t.setmj(100);
printf("mj = %d\n",t.getmj());//100
printf("mk = %d",t.mk);//可以读取数据
return 0;
}
2.我们也可以通过定义指针或者引用的方式 改变指针地址或引用变量的值来改变const成员的值
#include <stdio.h>
class Test
{
public:
int *mp;
int &ref;
private:
const int mi;
public:
Test():mi(0),mp(const_cast<int*>(&mi)),ref(const_cast<int&>(mi))
{
}
Test(const Test&t):mi(0)//,mp(const_cast<int*>(&mi)),ref(const_cast<int&>(mi))
{
}
int getmi()
{
return mi;
}
};
int main()
{ Test t;
*t.mp = 100;
printf("mi = %d\n",t.getmi());//100
t.ref = 1000;
printf("mi = %d\n",t.getmi());//1000
return 0;
}