对new和delete的理解,灵活使用
2013-09-27 09:34
253 查看
我记得当年学习C++基础的时候,老师曾经告诉我们:一般来说new和delete要成对出现,在使用完new申请的内存后要马上释放。我相信持这种说法的人不止我们老师一个人,养成良好的内存使用习惯固然重要,但如果因此就认为new和delete必须成对出现,使用完new得到的空间后就要马上用delete释放的话,就有点“大材小用”了,相信C++提供这一由用户控制的内存控制方法也不是只限于如此的使用方法。
正确灵活的,或许也是“高级”的使用方法,是在A处使用new申请一块内存,用一个指针指pA向它,之后在B处用指针pB指向pA所指向的空间,释放指针pA本身,接着释放pB所指向的内存空间,最后释放指针pB本身。
以下的代码是本过程的一个例子:
#include<iostream.h>
#include<string.h>
char* ReverseString(char* pSourceStr,int nLength)
{
//这里在堆上动态申请了一个长度为nLength的内存空间pDescStr
char* pDescStr=new char[nLength];
for(int i=0;i<nLength;i++)
{
pDescStr[nLength-i-1]=pSourceStr[i];
}
//结束前并没有释放pDescStr所指向的内存空间
return pDescStr;
//只是释放了pDescStr这个指针
}
void main()
{
char pSourceStr[]={"abcdefghijk"};
cout<<"The source string: \t"<<pSourceStr<<endl;
//新建一个指向ReverseString()函数中申请到的内存的指针
char* pDescStr=ReverseString(pSourceStr,strlen(pSourceStr));
cout<<"The desc string: \t"<<pDescStr<<endl;
//在这里释放ReverseString()函数中申请到的内存
delete[] pDescStr;
//清除pDescStr指针,以免在今后的使用中出现溢出
pDescStr=NULL;
}
从上面的例子可以看出,new和delete并没有在同一个函数中出现,但是很明显这样做没有造成内存泄露(memory leak)。
或许这样使用new和delete有点小儿科,达到ReverseString()函数的目的完全可以不必使用new和delete。我认为new和delete最大的用武之地是在线程通信和进程通信中:比如线程A要向线程B投递一条信息,并要求不等线程B做出反应线程A就要马上进行后面的操作,也就是要求使用PostMessage(...)函数来投递消息,而且发送的消息内容存储在一个50K或者更大的内存空间中,那就必须使用new和delete了,也就是在线程A中用new准备好这样一个庞大的消息,之后把指针发送给进程B,进程B在处理完消息之后用delete释放这块内存。
另一个例子:
char *GetMemory3(int num)
{
char *p = (char *)malloc(sizeof(char) * num);
return p;
}
void Test3(void)
{
char *str = NULL;
str = GetMemory3(100);
strcpy(str, "hello");
cout<< str << endl;
free(str);
}
总而言之,new和delete并非我们想像的那么简单,除了我所提到的用处之外还有不少其他的用处,有待研究。
正确灵活的,或许也是“高级”的使用方法,是在A处使用new申请一块内存,用一个指针指pA向它,之后在B处用指针pB指向pA所指向的空间,释放指针pA本身,接着释放pB所指向的内存空间,最后释放指针pB本身。
以下的代码是本过程的一个例子:
#include<iostream.h>
#include<string.h>
char* ReverseString(char* pSourceStr,int nLength)
{
//这里在堆上动态申请了一个长度为nLength的内存空间pDescStr
char* pDescStr=new char[nLength];
for(int i=0;i<nLength;i++)
{
pDescStr[nLength-i-1]=pSourceStr[i];
}
//结束前并没有释放pDescStr所指向的内存空间
return pDescStr;
//只是释放了pDescStr这个指针
}
void main()
{
char pSourceStr[]={"abcdefghijk"};
cout<<"The source string: \t"<<pSourceStr<<endl;
//新建一个指向ReverseString()函数中申请到的内存的指针
char* pDescStr=ReverseString(pSourceStr,strlen(pSourceStr));
cout<<"The desc string: \t"<<pDescStr<<endl;
//在这里释放ReverseString()函数中申请到的内存
delete[] pDescStr;
//清除pDescStr指针,以免在今后的使用中出现溢出
pDescStr=NULL;
}
从上面的例子可以看出,new和delete并没有在同一个函数中出现,但是很明显这样做没有造成内存泄露(memory leak)。
或许这样使用new和delete有点小儿科,达到ReverseString()函数的目的完全可以不必使用new和delete。我认为new和delete最大的用武之地是在线程通信和进程通信中:比如线程A要向线程B投递一条信息,并要求不等线程B做出反应线程A就要马上进行后面的操作,也就是要求使用PostMessage(...)函数来投递消息,而且发送的消息内容存储在一个50K或者更大的内存空间中,那就必须使用new和delete了,也就是在线程A中用new准备好这样一个庞大的消息,之后把指针发送给进程B,进程B在处理完消息之后用delete释放这块内存。
另一个例子:
char *GetMemory3(int num)
{
char *p = (char *)malloc(sizeof(char) * num);
return p;
}
void Test3(void)
{
char *str = NULL;
str = GetMemory3(100);
strcpy(str, "hello");
cout<< str << endl;
free(str);
}
总而言之,new和delete并非我们想像的那么简单,除了我所提到的用处之外还有不少其他的用处,有待研究。
相关文章推荐
- 类特定的new和delete的使用及理解
- 类特定的new和delete的使用及理解
- Effective c++ 条款16学习笔记: 成对使用new和delete时要采取相同形式
- new/delete和malloc/free区别,能否交叉使用
- C++中关于new和delete的使用
- 理解各种不同含义的new和delete
- C++中new和delete的使用方法详解
- new与delete必须成对使用
- new/delete和malloc/free的使用场合和区别
- c++ 内存管理:9、malloc/free的使用要点 new/delete的使用要点
- 动态开辟空间new和delete的使用实例
- c++中new和delete的使用方法
- C/C++内存使用之malloc/free,new/delete
- c++中new和delete的使用方法
- C++ - new/delete与new[]/delete[]必须配对使用
- 读书笔记《Effective c++》 条款16 成对使用new和delete时要采用相同形式
- Effective C++——》条款16:成对使用new和delete时要采取相同的形式
- Effective C++条款16解读:成对使用new和delete时要采取相同形式
- 理解new和delete
- c++中new和delete的使用方法