手机
当前位置:查字典教程网 >编程开发 >C语言 >C语言new操作的安全性分析
C语言new操作的安全性分析
摘要:对于学习过C语言的朋友应该都知道,使用malloc/calloc等分配内存的函数时,一定要检查其返回值是否为“空指针”(亦即检查分配内存的操...

对于学习过C语言的朋友应该都知道,使用 malloc/calloc 等分配内存的函数时,一定要检查其返回值是否为“空指针”(亦即检查分配内存的操作是否成功),这是良好的编程习惯,也是编写可靠程序所必需的。但是,如果你简单地把这一招应用到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语言实践OOP,以及new,delete的深入分析

对C语言中sizeof细节的三点分析介绍

C语言中的内存泄露 怎样避免与检测

c语言中return与exit的区别浅析

浅析C语言中assert的用法

C/C++语言中结构体的内存分配小例子

C语言中函数与指针的应用总结

基于C程序启动代码的深入分析

C语言函数的递归和调用实例分析

浅析C语言中的内存布局

精品推荐
分类导航