看下面的代码和gcc给出的报错信息有助于理解非静态成员函数后面的const意思了。
非静态成员函数后面的const作用其实就是限定了函数内部不可改变数据成员的值。
#include <iostream>
using namespace std;
class A{
int data;
public:
A(int da=100):data(da) {}
void display1() {cout << data << endl;}
void display2() const {cout << data << endl;}
void display3() const
{
data+=100;
cout << data << endl;
}
};
int main()
{
A a1;
const A a2;
a1.display1(); //right
a1.display2(); //right
a1.dispaly3(); //error ,const声明的成员函数不能改变数据成员的值
a2.display1(); //error ,const对象不能调用非const函数
a2.display2(); //right
a2.display3(); //error ,const声明的成员函数不能改变数据成员的值
return 0;
}
我们用控制变量法来分析一下以上的例子。
【先把a1.display3();这行留下,其他可能影响的语句注释掉】
const.cpp: 在成员函数‘void A::display3() const’中:
const.cpp:12:17: 错误: assignment of member ‘A::data’ in read-only object
const.cpp: 在函数‘int main()’中:
const.cpp:23:12: 错误: ‘class A’没有名为‘dispaly3’的成员
上面的报错信息前两句明确指出'void A::display3() const'中不能修改数据成员也就是data的值。data是只读的。
后面两句暂时不知为何。。。
【先把a2.display1();这行留下,其他可能影响的语句注释掉】
const.cpp: 在函数‘int main()’中:
const.cpp:24:21: 错误: 将‘const A’作为‘void A::display1()’的‘this’实参时丢弃了类型限定 [-fpermissive]
丢掉了const修饰。const对象不能调用非const函数,具体关于const和非const还请看我的另一篇博文:《C++中的const与非const的一点思考》【先把a2.display3();这行留下,其他可能影响的语句注释掉】
const.cpp: 在成员函数‘void A::display3() const’中:
const.cpp:12:17: 错误: assignment of member ‘A::data’ in read-only object
这个错误就和第一个错误是一样的了。const声明的成员函数不能改变数据成员的值。
另外,我们对比下还能有些发现~~~更能加深理解书本上的知识。
通过a1.display1()和a1.display2()可知非const对象可以调用const和非const函数。
通过a2.display1()和a2.display2()可知const对象只能调用const函数,不能调用非const函数。