說到C語言相信大家都很熟悉,我們在使用malloc/calloc等函數(shù)分配內(nèi)存時(shí),需要檢查malloc/calloc的返回值是否為“空指針”,這是作為編程的習(xí)慣,下面就讓武林技術(shù)頻道小編帶大家來學(xué)習(xí)C語言new操作的安全性分析。
實(shí)現(xiàn)代碼如下:
int * p = new int [MAXSIZE]if (p == 0) // 檢查p指針是否為空return -1;//other code
其實(shí),這里的 if ( p == 0 ) 完全沒有意義的。C++ 里,如果 new 分配內(nèi)存失敗,默認(rèn)是拋出異常的。所以,如果分配成功,p == 0 就絕對不會成立;而如果分配失敗了,也不會執(zhí)行 if ( p == 0 ),因?yàn)榉峙涫r(shí),new 就會拋出異常跳過后面的代碼。如果你想檢查 new 是否成功,應(yīng)該捕捉異常:
try{int * p = new int [MAXSIZE]}catch( bad_alloc & exp){cerrr<<exp.what()<<endl;}
但是 有的程序員并不習(xí)慣捕捉異常,標(biāo)準(zhǔn)C++也提供了一種方法不拋出異常而返回空指針。
int * p = new (std::nothrow)int [MAXSIZE]if (p == 0) // 檢查p指針是否為空return -1;//other code
以上就是關(guān)于C語言new操作的安全性分析的全部介紹,你學(xué)會了嗎?建議你好好收藏這篇文章,相信對你做編寫程序很有幫助,更多的有用信息請關(guān)注武林技術(shù)頻道!
新聞熱點(diǎn)
疑難解答
圖片精選