說到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操作的安全性分析的全部介紹,你學會了嗎?建議你好好收藏這篇文章,相信對你做編寫程序很有幫助,更多的有用信息請關注武林技術頻道!
新聞熱點
疑難解答
圖片精選