这个题目很奇怪啊,今天下午在看拷贝构造函数的时候,突然看到了很奇怪的一句话:
- class CExample
- {
- public:
- CExample(){pBuffer=NULL; nSize=0;}
- ~CExample(){delete pBuffer;}
- CExample(const CExample&);
- void Init(int n){ pBuffer=new char[n]; nSize=n;}
- private:
- char *pBuffer;
- int nSize;
- };
- CExample::CExample(const CExample& RightSides)
- {
- nSize=RightSides.nSize; //!!!!!!请注意这句话!!!!!!
- pBuffer=new char[nSize];
- memcpy(pBuffer,RightSides.pBuffer,nSize*sizeof(char));
- }
1.为什么对象a可以直接访问私有的x(a.x)成员见http://topic.csdn.net/u/20110504/22/738aede9-3909-4d74-82fd-8d4a2f2f12a5.html
给出了一个解答:因为A(const A&a)是他的成员函数。
在我的例子也是如此:CExample::CExample(const CExample& RightSides)是CExample的成员函数,所以可以访问同类型对象的私有成员。即RighSides.nSize的调用可以编译用过,但是,你在main函数里面直接写上:
- int main(int argc, char* argv[])
- {
- CExample theObjone;
- theObjone.nSize;
- return 0;
- }
随后,我又做了一个实验:
- #include <iostream>
- using namespace std;
- class T{
- private:
- int m_data;
- };
- class CTest
- {
- public:
- CTest(); //构造函数
- CTest(const CTest &); //复制构造函数
- CTest & operator = (const CTest &); //赋值符
- void print(){
- cout << m_data << endl;
- };
- int print1(const CTest &);
- int print2(const T&);
- private:
- int m_data;
- };
- CTest::CTest()
- {
- cout<<"Constructor of CTest"<<endl;
- }
- CTest::CTest(const CTest& arg)
- {
- cout << arg.m_data <<endl;
- cout<<"Copy Constructor of CTest"<<endl;
- }
- CTest & CTest::operator = (const CTest & arg)
- {
- cout<<"Assign function of CTest"<<endl;
- }
- int CTest :: print1(const CTest & arg){
- cout << arg.m_data <<endl;
- return 0;
- }
- int CTest::print2(const T& arg){
- cout << arg.m_data << endl;
- }
- int main()
- {
- CTest a;
- return 0;
- }
请注意print()、print1()、print2()的区别;
print()自然不用说,成员函数访问类的私有变量,编译通过;
print1():print1是CTest类的成员函数,而print1的形参是const CTest& arg,arg的类型就是CTest,根据成员函数可以访问私有变量,故编译通过
print2():print2是CTest类的成员函数,但是print2的形参类型是T,不是CTest,print2不是T的成员函数,不能访问类的私有变量,故编译不能通过