以前我一直使用的是返回首地址的方式,例如我的程序要返回一个旬数组,但是月份是动态的:
int* CJustWaterSatisfyRate::Fun_GetXun_Array(COleDateTime begin_time,COleDateTime end_time){
...//根据begin_time,end_time确定数组大小n
int* xun_array=new int[n];[2]//本想在次函数内删除,但是此函数要返回他的首地址,显然不能删除
...//对xun_array数组进行赋值
return xun_array;
}
使用的时候
CJustWaterSatisfyRate WSR;
int* xun_array=new int[n];[1]
xun_array=WSR.Fun_GetXun_Array(begin_time,end_time);//希望首地址赋值
for(int i=0;i<n;i++)
...//使用xun_array[i]进行其他操作
[color=#FF0000] delete xun_array;
xun_array=NULL;[/color]
程序可以运行,但是问题出现了,【1】处的释放不掉,红部分释放的,不是【1】处,而是【2】处,想了老半天,后来才想到首地址赋值真的是有问题,等于开辟了两块内存空间,我释放空间的时候,只释放了【2】处的空间,而【1】这个地方却没有动。
貌似释放是【1】处,实际上不是,后来我把函数改了,使用引用方式
void CJustWaterSatisfyRate::Fun_GetXun_Array(COleDateTime begin_time, COleDateTime end_time,int *xun_array)){
...//根据begin_time,end_time确定数组大小n
//此句被删除int* xun_array=new int[n];[2]//本想在次函数内删除,但是此函数要返回他的首地址,显然不能删除
...//对xun_array数组进行赋值
//此句被删除return xun_array;
}
使用的时候也变了:
int* xun_array=new int[n];//旬数组
WSR.Fun_GetXun_Array(begin_time,end_time,xun_array);//引用
这样,两个内存块被弄成一块了,删除就成功了。
int* CJustWaterSatisfyRate::Fun_GetXun_Array(COleDateTime begin_time,COleDateTime end_time){
...//根据begin_time,end_time确定数组大小n
int* xun_array=new int[n];[2]//本想在次函数内删除,但是此函数要返回他的首地址,显然不能删除
...//对xun_array数组进行赋值
return xun_array;
}
使用的时候
CJustWaterSatisfyRate WSR;
int* xun_array=new int[n];[1]
xun_array=WSR.Fun_GetXun_Array(begin_time,end_time);//希望首地址赋值
for(int i=0;i<n;i++)
...//使用xun_array[i]进行其他操作
[color=#FF0000] delete xun_array;
xun_array=NULL;[/color]
程序可以运行,但是问题出现了,【1】处的释放不掉,红部分释放的,不是【1】处,而是【2】处,想了老半天,后来才想到首地址赋值真的是有问题,等于开辟了两块内存空间,我释放空间的时候,只释放了【2】处的空间,而【1】这个地方却没有动。
貌似释放是【1】处,实际上不是,后来我把函数改了,使用引用方式
void CJustWaterSatisfyRate::Fun_GetXun_Array(COleDateTime begin_time, COleDateTime end_time,int *xun_array)){
...//根据begin_time,end_time确定数组大小n
//此句被删除int* xun_array=new int[n];[2]//本想在次函数内删除,但是此函数要返回他的首地址,显然不能删除
...//对xun_array数组进行赋值
//此句被删除return xun_array;
}
使用的时候也变了:
int* xun_array=new int[n];//旬数组
WSR.Fun_GetXun_Array(begin_time,end_time,xun_array);//引用
这样,两个内存块被弄成一块了,删除就成功了。