结构化异常捕获空指针异常
生活随笔
收集整理的這篇文章主要介紹了
结构化异常捕获空指针异常
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
以前學PE時寫了一個檢驗二進制數據是不是PE文件的函數:
// 驗證是否是合法的32位PE文件 BOOL Is32PEFile(LPVOID pFileBuffer, DWORD dwSize) {PIMAGE_DOS_HEADER pDosHeader = (PIMAGE_DOS_HEADER)pFileBuffer;PIMAGE_NT_HEADERS pNtHeader = (PIMAGE_NT_HEADERS)((DWORD)pDosHeader + pDosHeader->e_lfanew);if (pDosHeader->e_magic != IMAGE_DOS_SIGNATURE){PrintDebugInfo("不是有效的MZ標志 %x != %x", pDosHeader->e_magic, IMAGE_DOS_SIGNATURE);return FALSE;}if (pNtHeader->Signature != IMAGE_NT_SIGNATURE){PrintDebugInfo("不是有效的PE標記");return FALSE;}if (pNtHeader->FileHeader.Machine != IMAGE_FILE_MACHINE_I386){PrintDebugInfo("不是32位PE程序");return FALSE;}return TRUE; }這個實現其實是不行的,如果文件讀進來是一堆亂碼,那很可能指針會亂指,然后引用非法內存,所以改寫這個函數,加入了非法訪問內存的異常捕獲:
// 驗證是否是合法的32位PE文件 BOOL Is32PEFile(LPVOID pFileBuffer, DWORD dwSize) {__try{PIMAGE_DOS_HEADER pDosHeader = (PIMAGE_DOS_HEADER)pFileBuffer;if (*((PWORD)pDosHeader) != IMAGE_DOS_SIGNATURE){return FALSE;}PIMAGE_NT_HEADERS pNTHeader = (PIMAGE_NT_HEADERS)((DWORD)pDosHeader + pDosHeader->e_lfanew);if (pNTHeader->Signature != IMAGE_NT_SIGNATURE){return FALSE;}if (pNTHeader->OptionalHeader.Magic != IMAGE_NT_OPTIONAL_HDR32_MAGIC){return FALSE;}return TRUE;}__except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ? EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH){return FALSE;} }總結
以上是生活随笔為你收集整理的结构化异常捕获空指针异常的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第二次爬虫,更加熟练啦
- 下一篇: bat脚本+vs2019编译openss