众所周知,C++类实现函数重载有两种情况:函数参数的类型不同,参数的个数不同。而与函数的返回值没有什么关系。还有一种类成员函数重载,它并不要求函数的参数类型不同。下面给出例子:
#include <iostream> using namespace std; class A { public: A(int a):_a(a){} void print()const//函数体中不能修改数据成员对象,否则报错 { cout <<"const " << _a << endl; } void print()//函数体中可修改成员对象 { _a = 23; cout <<"non-const " << _a << endl; } private: int _a; }; int main() { A a(12); a.print();//如果以上没有non-const重载,那么此处执行const函数 const A b(12); b.print(); return 0; }
上面的代码运行结果为:
non-const 23 const 12
因此类成员函数重载并不是绝对的参数列表中参数类型必须不同。为什么可以这样。这其实涉及到了C++对象模型的底层实现。类的这两种函数编译后,其登记的名字是不同的,因此可以共同存在。
转载请注明出处(http://blog.csdn.net/gulansheng/article/details/45827755)
原文地址:http://blog.csdn.net/gulansheng/article/details/45827755