为什么两个CString 数据不能用"operator="

博主在做文件夹同步小软件时,遇到两个CString对象不能用“operator=”的问题。分析发现用malloc分配内存未调用构造函数,而new会调用。因需扩展空间不能用new,最终修改数据结构为链表解决问题,还提出用STL中vector的可能解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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,这里只是提出这种可能的解决方法,还不知道能不能行的通,只有等以后有了这份闲心再慢慢研究了。如果各位网友有什么意见,请不吝赐教~!

根据给定的main函数完成CSTRING类的设计,使得下面程序能够正确运行出要求的结果。 #include<iostream> #include<cstring> using namespace std; /* 你提交的代码在这里 */ int main() { CSTRING t; cout<<"Length of string:"<<strlen(t.GetData())<<endl; t.Set("This is an example"); t.Show(); cout<<"Length of string:"<<strlen(t.GetData())<<endl; t="Sample"; cout<<t<<endl; int n,i; cin>>n; CSTRING s,*cs; cs=new CSTRING[n]; for(i=0;i<n;i++) { cin>>cs[i]; s+=cs[i]; } for(i=0;i<n;i++) cout<<"("<<i+1<<") "<<cs[i]<<endl; cout<<s<<endl; int j; for(i=0;i<n-1;i++) for(j=0;j<n-i-1;j++) if(cs[j]>cs[j+1]) { t=cs[j]; cs[j]=cs[j+1]; cs[j+1]=t; } for(i=0;i<n;i++) cout<<"("<<i+1<<") "<<cs[i]<<endl; t[0]='\0'; for(i=0;i<n;i++) { t=cs[i]+t; } cout<<t<<endl; delete[] cs; return 0; }#include<iostream> #include<cstring> using namespace std; /* 你提交的代码在这里 */ #include<string> class CSTRING{ public: char *GetData() { char p[10000]; strcpy(p,t.c_str()); return p; } CSTRING():t(""){}; CSTRING(const CSTRING&a):t(a.t){} void Set(const string &a) { t=a; } void Show(){cout<<t<<endl;} CSTRING operator =(const string p) {t=p;return *this;} friend ostream& operator <<(ostream&a,CSTRING&b) {a<<b.t;return a;} friend istream& operator >>(istream&a,CSTRING&b) {a>>b.t;return a;} bool operator>(CSTRING&b) {if(t.compare(b.t)>0)return true;else return false;} CSTRING operator+(CSTRING &b) { CSTRING p; p.t=t+b.t;return p; } CSTRING operator+=(CSTRING &b) { //CSTRING P; t=t+b.t;return *this; } //friend CSTRING operator +(CSTRING&a,CSTRING&b) //{ //CSTRING p;p.t=a.t+b.t; //return p; //} char& operator[](int n) { return t[n]; } private:string t; };怎么改:
最新发布
06-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值