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));


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM