C语言new操作的安全性分析

来源:爱站网时间:2019-08-10编辑:网友分享
说到C语言相信大家都很熟悉,我们在使用malloc/calloc等函数分配内存时,需要检查malloc/calloc的返回值是否为“空指针”,这是作为编程的习惯,下面就让爱站技术频道小编带大家来学习C语言new操作的安全性分析。

说到C语言相信大家都很熟悉,我们在使用malloc/calloc等函数分配内存时,需要检查malloc/calloc的返回值是否为“空指针”,这是作为编程的习惯,下面就让爱站技术频道小编带大家来学习C语言new操作的安全性分析。

实现代码如下:

int * p = new int [MAXSIZE]
if (p == 0) // 检查p指针是否为空
return -1;
//other code

其实,这里的 if ( p == 0 ) 完全没有意义的。C++ 里,如果 new 分配内存失败,默认是抛出异常的。所以,如果分配成功,p == 0 就绝对不会成立;而如果分配失败了,也不会执行 if ( p == 0 ),因为分配失败时,new 就会抛出异常跳过后面的代码。如果你想检查 new 是否成功,应该捕捉异常:

try
{
int * p = new int [MAXSIZE]
}
catch( bad_alloc & exp)
{
cerrr<<exp.what()<<endl;
}

但是 有的程序员并不习惯捕捉异常,标准C++也提供了一种方法不抛出异常而返回空指针。

int * p = new (std::nothrow)int [MAXSIZE]
if (p == 0) // 检查p指针是否为空
return -1;
//other code

以上就是关于C语言new操作的安全性分析的全部介绍,你学会了吗?建议你好好收藏这篇文章,相信对你做编写程序很有帮助,更多的有用信息请关注爱站技术频道!

上一篇:汇总C语言实现顺序表的基本操作

下一篇:汇总C语言单链表的常见操作方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载