C++早期版本的new在失败时会返回NULL,但新版本不是这样。这不利于严格的内存检查,可能会造成隐患。安全的做法是:
#include <new>
……
char *pch=new(std::nothrow)char[1000000000];
if(pch==NULL)
{
//错误处理
}
为了方便使用,还可以定义下面的宏:
#define sfnew new(std::nothrow)
接下来使用sfnew就能保证在new失败时能得到NULL,以便做相应的错误处理。该方法在windows、Ubuntu、Android均通过了验证。
执行这样的测试片段,
{
char *pch=(char*)1;
printf("testpch=%p.",pch);
pch=new(std::nothrow)char[500000000000];
printf("testpch=%p.",pch);
}
可用看到超量分配内存失败的时候,new返回了NULL。
另一种安全的new应用相对比较繁琐,就是在所有使用new的地方采用try-catch捕获错误。