1、出了什么问题?
最近在做一个文件夹同步的小软件时,碰到了一点小小的麻烦——两个CString对象不能用“operator=”。首先还是看看我的数据结构吧。
class CFileInfo //文件信息类
{
public:
......
CFileInfo & operator=(const CFileInfo &fileInfo);
public:
CString m_strPath; //文件路径
CString m_strFileName; //文件名
CTime m_mTime; //文件最后被修改的时间
DWORD m_size; //文件大小
}
......
class COperator //文件操作类
{
......
public:
CFileInfo *leftFileArray; //左文件夹信息数组
......
}
该设计需要为leftFileArray动态分配内存,我在COperator类的构造函数中使用了malloc函数:
leftFileArray = (CFileInfo*)malloc(sizeof(CFileInfo) * MAX_SIZE);
但是当我需要为leftFileArray[i]赋值的时候就出现问题了:
leftFileArray[i] = fileInfo; //使用了上面定于的赋值操作符
CFileInfo& CFileInfo::operator=(const CFileInfo &fileInfo)
{
m_mTime = fileInfo.m_mTime;
m_size = fileInfo.m_size;
m_strFileName = fileInfo.m_strFileName; //出现问题的地方
m_strPath = fileInfo.m_strPath;
return (*this);
}
2、为什么会出现这个问题?
首先看sizeof(CFileInfo) = 20B
也就是说leftFileArray[i]的空间是20B,而leftFileArray[i]中有一个数据时CString,CString的大小可能会大于20B。于是,问题似乎已经浮出水面,但是到现在为止,我们还只看到问题的一部分。
我试着用new为leftFileArray分配空间:leftFileArray = new CFileInfo[MAX_SIZE];
令人惊讶的事情发生了,这次m_strFileName = fileInfo.m_strFileName;语句不再出现任何问题。
为什么会出现这种情况呢?我开始了一番调试后终于发现了问题:当我用malloc进行内存分配时,除了我上面出现的问题外,还有就是整个程序致死没有调用CFileInfo类的构造函数,而当我们用new操作符时,他是会自动调用CFileInfo 的构造函数的。到了这里,我想问题已经彻底暴露了(个人认为是这样)。
3、怎样解决这个问题?
因为我为leftFileArray数组分配的空间是可能会扩展的,所以我不能用new 操作符,我曾想过找找MFC中是否有类似new 操作符,同时又具有malloc,relloc功能的函数,很不幸的是我没有找到。最后没有办法,我只有从新修改了我的数据结构,将原本要设计成动态数组的leftFileArray设计成链表,为CFileInfo类再添加一个数据成员:CFileInfo *pNext = NULL;这样我再为每一个CFileInfo节点用new操作符进行内存分配,这样就解决了问题。
4、还有其他解决办法吗?
我也曾考虑过用STL中的vector,但是由于本人知识匮乏,对STL还是一知半解,再加上时间有限,我暂时没有尝试用vector,这里只是提出这种可能的解决方法,还不知道能不能行的通,只有等以后有了这份闲心再慢慢研究了。如果各位网友有什么意见,请不吝赐教~!