簡體   English   中英

在C ++中寫入隨機內存塊時如何捕獲異常

[英]How to catch exception when write to a random memory block in c++

int main()
{
    int *a; // a = 0x4053c6 (a random address)
    // this will cause the program to exit, and how do i know this memory can't be written ?
    *a = 5;
    return 0;
}

困惑! 我的意思是,此代碼段總是導致程序崩潰嗎? 並且該程序是否可以從頭到尾執行?

該代碼將出現Segfault /具有訪問沖突,根據操作系統的不同,該訪問沖突將作為陷阱或信號處理。 您也許可以處理它,但是事后再執行其他操作的可能性很小。 (處理該問題后的通常做法是正常退出)。

至於確定存在這種情況,將很難證明這一點。 您可以擁有自己的編譯器,該編譯器將未初始化的變量設置為堆棧上的特定地址,例如(sarcasm)。

偽初始化a中的值的一種方法是調用一個函數:

void func(int k)
{
    int *a;
    int b = 0;
    if (k == 1) {
        a = &b;
    }
    *a = 5;
}

您可以嘗試使用func(1)幾次,然后再嘗試func(2)。 a和b有可能會重用相同的堆棧區域並且不會失敗。 但這又是一次機會

通常會導致崩潰,但是不能保證(由於變量未初始化,因此可以包含任何值,有效或無效)。 您無法使用C ++異常捕獲訪問沖突,但編譯器會提供擴展來實現此目的。 例如,對於Visual C ++,可以使用SEH(結構化異常處理):

#include <Windows.h>
#include <iostream>

using namespace std;

int main()
{
    int* p = reinterpret_cast<int*>(0x00000100);

    __try
    {
        *p = 10;
    }
    __except (GetExceptionCode() == EXCEPTION_ACCESS_VIOLATION ? EXCEPTION_EXECUTE_HANDLER : EXCEPTION_CONTINUE_SEARCH)
    {
        cout << "Access violation" << endl;
        return -1;
    }

    cout << *p << endl;
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM