OpenJudge第三周测试—04

004:这个指针哪来的

描述
填空,按要求输出

#include 
using namespace std;

struct A
{
	int v;
	A(int vv):v(vv) { }
// 在此处补充你的代码
};

int main()
{
	const A a(10);
	const A * p = a.getPointer();
	cout << p->v << endl;
	return 0;
}

输入

输出

10

样例输入

样例输出

10

代码

const A *getPointer()const {
		return this;
	}

分析
注意main函数里的a对象是const型,如果我们把这条语句改一下

const A * p = new A(a);

那么我们就能得到正确答案,所以我们调用这个函数需要返回的是a对象
思路
返回语句:return *this,由于p指针是const A *p,所以这是一个指针指向一个常量,不能通过指针来修改这个指针指向的值,那么调用这个函数的返回值也应该是const型,在函数前加const,这个时候会看到报错
OpenJudge第三周测试—04_第1张图片
原因:
1)const对象只能调用const函数,常量成员和常量函数非常封闭;
2)如果const函数中不小心修改了类成员或者调用了非常量函数,编译器会找出这类错误。
类中函数前、中、后加const的区分:
1、参数加const:int fun(const int a),a在函数里不可被修改
2、函数前加const:const int* const fun(),这种一般是返回的指针或者是引用,加const是规定返回值不可被修改(不能作为左值)
3、函数后加const:int fun()const,这个函数不能访问类中所有this所能调用的内存,即这是个只读函数

你可能感兴趣的:(OpenJudge)