生活随笔
收集整理的這篇文章主要介紹了
C++ 中判断非空的错误指针
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
最近在寫網絡上的東西,程序經過長時間的運行,會出現崩潰的問題,經過DUMP文件的查看,發現在recv的地方接收返回值的時候,數據的長度異常的大差不多16億多字節.而查看分配后的char指針顯示為錯誤的指針,這可能是接收數據不對應產生的問題解決思路如下: 1.對返回值長度進行判斷,如果超過項目內最大的返回值就直接return(比如我項目內的最大返回值為5000,哪么我設定的值為10000); 2.對char指針進行判斷,由于這里返回的數據是有的,只是解析不出來而已,這里就是一個非空的錯誤指針,所以進行二次驗證,使用IsBadWritePtr這個API如下實例:
| BOOL WINAPI IsBadWritePtr( _In_ LPVOID LP, _In_ UINT_PTR UCB ); |
參數 LP [中] 一個指向內存塊的第一個字節。 UCB [中] 該內存塊的大小,以字節為單位。如果這個參數是零,則返回值是零。 返回值 如果調用進程具有寫訪問指定的內存范圍內的所有字節,則返回值為零。 如果調用進程不具有寫訪問指定的內存范圍內的所有字節,則返回值為非零值。 如果應用程序在調試器下運行,進程不具有寫訪問權限在指定的內存范圍內的所有字節,該函數會導致第一次機會STATUS_ACCESS_VIOLATION例外。調試器可以被配置為打破這個條件??。恢復執行的過程在調試器中后,該功能將繼續像往常一樣,并返回一個非零值這個行為是經過設計,并作為輔助調試。
| //---------------------------------------------------------------------------- //這是一個測試1 char *pbuf1 = new char[10]; pbuf1 = (char *)0x0; ? //經過這里賦值 pbuf現在是一個錯誤的指針 bool br1 = IsBadWritePtr(pbuf1,10); ?//返回的值是true if(!br1) { memcpy(pbuf1,"111111111",10); cout << pbuf1 << endl; printf("Display1:%s \n",pbuf1); } //這是一個測試2 char *pbuf2 = new char[10]; bool br2 = IsBadWritePtr(pbuf2,10); ?//返回的值是true if(!br2) { memcpy(pbuf2,"222222222",10); printf("Display2:%s \n",pbuf2); } //輸出結果 //Display2:222222222 //---------------------------------------------------------------------------- MFC里也可以使用AfxIsValidAddress方法判斷。 // Allocate a 5 character array, which should have a valid memory address. char *array = new char[5]; // Create a null pointer, which should be an invalid memory address. char *null = (char *)0x0; ASSERT(AfxIsValidAddress(array, 5)); ASSERT(!AfxIsValidAddress(null, 5)); |
總結
以上是生活随笔為你收集整理的C++ 中判断非空的错误指针的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。