1.常量形参
当形参有顶层const或者底层const的时候,传给它常量对象或者非常量对象都是可以的,在这里我们主要考虑形参无const, 而实参有const的情况,其实这里也十分简单,只需要记住一点:底层const的限制,就可以了。
2.常量返回值
这里也很简单,略过不提。
3.常量成员函数
常量函数里的const是用来修饰*this的,其形式如下:
1
|
int f() const {```}
|
然后这里就有意思了
*this的默认类型是type *const this,this指针有一个顶层const,但并没有底层const,由于低层const的限制,有底层const的实参不能拷贝给默认版的*this,也就是说常量对象的引用或指针都不能调用默认版的*this成员函数。
还没完。。。
刚刚我们已经明确了有底层const的实参是无法初始化默认版*this,但是拥有顶层const的对象是不是就能初始化默认版的*this, 然后调用函数呢?
不是。。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
//定义一个简单类student
class student{
public :
string name;
int number;
public :
student() :name( "lili" ), number(0){ } //构造函数
string Name(){ return name;} //非常量成员函数
int Number() const { return number;} //常量成员函数
};
//现在定义一个常量student对象
const student s1;
s1.Name(); //报错
s1.Number(); //正确
|
事实上,当我们调用s1.Name()的时候发生了以下初始化过程:
1
|
student * const this =&s1;
|
此时相当于如下过程:
1
2
|
const student *s1;
student * const this =s1;
|
很显然s1有一个底层const, 而this没有,初始化失败。
同理,如果一个实参是 int *const p,那么在初始化this的时候,会转化成const int *const p, 有一个底层const, 初始化失败。
综述:常量对象,常量对象的指针或者引用都只能调用常量成员函数。
原文链接:http://blog.csdn.net/jang1996/article/details/52759263