C++的const和C语言的差别非常大,在C++中const修饰的变量是真正意义上的常量,虽然能取地址,但不能修改;在C语言中,const是一个伪常量,修饰的变量可以通过指针修改。
1.在C++中const还可以修饰类的成员函数,代表着常函数,不能修改类的成员数据。
#include<iostream>
class Person
{
private:
int age;
public:
Person(int);
void change(int)const;//修饰类的成员函数
};
Person::Person(int age)
{
this->age=age;
}
void Person::change(int age)const//定义时还需要带上const修饰
{
this->age=age;
std::cout<<"age="<<age<<"\n";
}
void main()
{
Person p1(20);
p1.change(21);//尝试调用change函数
std::cin.get();
}
在VS2013进行编译后,报错提示:正在通过常对象访问age。
那么如果非要通过const函数修改类的属性呢?
C++提供了mutable这个关键词,用它修饰的变量可以不受const约束。
mutable int age;
在int age前面加上mutable后,const函数可以修改属性的值
2.如果用const实例化一个对象又会是什么情况?
#include<iostream>
class Person
{
private:
mutable int age;
public:
Person(int);
void change(int)const;//修饰类的成员函数
void print();//增加一个没有const修饰的成员函数
};
Person::Person(int age)
{
this->age=age;
}
void Person::change(int age)const//定义时还需要带上const修饰
{
this->age=age;
std::cout<<"age="<<age<<"\n";
}
void Person::print()
{
std::cout<<"from print"<<"\n";
}
void main()
{
const Person p1(20);//实例化时带上const修饰
p1.change(21);//尝试调用change函数
p1.print();
std::cin.get();
}
VS2013报错提示:不能将“this”指针从“const Person”转换为“Person &”。
也就是说用const实例化一个类后是常对象,而没有被const修饰的成员函数常对象因为类型问题没有办法访问,因为C++是强类型的语言和弱类型的C还是有很大区别。如果非得要调用只能通过类型强转。
对代码做出下面的修改:
const Person p1(20);//实例化时带上const修饰
p1.change(21);//尝试调用change函数
Person *p = (Person *)&p1;//对p1进行类型强转
p->print();
对类型强转后成功访问:
3.总结:
(1)const修饰的成员函数不能对类的成员数据做出修改,但mutable关键词可以去掉const限制
(2)const修饰实例化后的对象时常对象,可以访问带有const修饰的成员函数,但不能访问没有带const修饰的成员函数
(3)C++是强类型的语言,类型不同是不允许访问的