今天一同事出去面试回来,带回来一道题,呵呵。
给定一个字符串的类,类的各成员和函数已经定义。现在要求,根据定义,写出各个函数的实现。类的定义如下:
class CMyString
{
public:
CMyString(const CMyString &a_cOther); // 构造函数,使构造函数的各成员属性与a_cOther相同,(不妨设函数1)
CMyString(char * a_pcStr = NULL); // 构造函数,将字符串a_pcStr复制给m_pcData;(函数2)
CMyString & operator = (const CMyString &a_cOther); // 等号操作符 (函数3)
virtual ~CMyString(); //析构函数 (函数4)
private:
char *m_pcData;
};
现在遇到的情况是,函数2和函数4容易写,但是函数1和函数3比较难。
我粗略一想,这还不容易,三下五除二解决了。程序的实现如下:
CMyString::CMyString(char * a_pcStr)
{
if(a_pcStr == NULL)
{
m_pcData = NULL;
}else
{
int iLen;
iLen = strlen(a_pcStr);
m_pcData = (char *)malloc(sizeof(char) * (iLen + 1));
memset(m_pcData,'\0',sizeof(char) * (iLen + 1));
strcpy(m_pcData,a_pcStr);
}
}
CMyString::CMyString(const CMyString &a_cOther)
{
memcpy(this,&a_cOther,sizeof(CMyString));
}
CMyString & CMyString::operator = (const CMyString &a_cOther)
{
CMyString *pTmpStr;
pTmpStr = new CMyString(a_cOther);
return *pTmpStr;
}
CMyString::~CMyString()
{
if(m_pcData != NULL)
{
free(m_pcData);
m_pcData = NULL;
}
}
为了测试,写了测试程序,如下:
char cTmp[] = "HelloWorld";
CMyString StrA(cTmp);
CMyString StrB(StrA);
CMyString StrC = StrB;
发现 函数的实现没有错,呵呵,完成,OK!
但是在仔细一看,不对呀,怎么StrA.m_pcData,StrB.m_pcData和StrC.m_pcData指向同一个地址啊!哦,对,在函数1和函数3中,我仅仅只复制了私有成员m_pcData的指针,所以这个类的三个对象的私有变量m_pcData都指向了同一个地址。
原来,我的方法不对。当然,函数2和函数4的正确性是无庸置疑的。
后来,一个同事终于做出来了。函数1和函数3代码如下:
CMyString::CMyString(const CMyString &a_cOther)
{
if(a_cOther.m_pcData == NULL)
{
m_pcData = NULL;
}else
{
int iLen;
iLen = strlen(a_cOther.m_pcData);
m_pcData = (char *)malloc(sizeof(char) * (iLen + 1));
memset(m_pcData,'\0',sizeof(char) * (iLen + 1));
strcpy(m_pcData,a_cOther.m_pcData);
}
}
CMyString & CMyString::operator = (const CMyString &a_cOther)
{
if(a_cOther.m_pcData == NULL)
{
m_pcData = NULL;
}else
{
int iLen;
iLen = strlen(a_cOther.m_pcData);
if(m_pcData = NULL)
{
m_pcData = (char *)malloc(sizeof(char) * (iLen + 1));
}else
{
m_pcData = (char *)realloc(m_pcData,sizeof(char) * (iLen + 1));
}
memset(m_pcData,'\0',sizeof(char) * (iLen + 1));
strcpy(m_pcData,a_cOther.m_pcData);
}
return *this;
}
编译一遍,正确!
但是令我疑惑不解的是,CMyString a_cOther的变量m_pcData明明是私有的,为什么可以访问他的私有变量呢?在其他函数中不行,在构造函数里可以访问呢?疑惑中……
看来是我对C++中的私有变量理解不是很透彻。
呵呵,好晚了,明天看看《C++标准》,应该可以从中找出答案吧!