共用方式為


unsafe (C# 參考)

關鍵詞 unsafe 表示不安全的內容,這是任何涉及指標的作業所需的內容。 如需詳細資訊,請參閱 不安全的程式代碼和指標

C# 語言參考資料記錄了 C# 語言最新版本。 同時也包含即將推出語言版本公開預覽功能的初步文件。

文件中標示了語言最近三個版本或目前公開預覽版中首次引入的任何功能。

小提示

欲查詢某功能何時首次在 C# 中引入,請參閱 C# 語言版本歷史的條目。

在類型或成員宣告時使用 unsafe 修飾符。 該類型或成員的整個文本範圍是不安全的語境。 例如,以下方法會以 unsafe 修飾符宣告:

unsafe static void FastCopy(byte[] src, byte[] dst, int count)
{
    // Unsafe context: can use pointers here.
}

不安全上下文的範圍從參數清單延伸到方法的結尾,因此你也可以在參數清單中使用指標:

unsafe static void FastCopy ( byte* ps, byte* pd, int count ) {...}

你也可以使用不安全的區塊來啟用該區塊內的不安全程式碼。 例如:

unsafe
{
    // Unsafe context: can use pointers here.
}

若要編譯不安全的程序代碼,您必須指定 AllowUnsafeBlocks 編譯程式選項。 通用語言執行時無法驗證不安全的程式碼。

範例

// compile with: -unsafe
class UnsafeTest
{
    // Unsafe method: takes pointer to int.
    unsafe static void SquarePtrParam(int* p)
    {
        *p *= *p;
    }

    unsafe static void Main()
    {
        int i = 5;
        // Unsafe method: uses address-of operator (&).
        SquarePtrParam(&i);
        Console.WriteLine(i);
    }
}
// Output: 25

C# 語言規格

如需詳細資訊,請參閱 C# 語言規格中的不安全程式碼。 語言規格是 C# 語法和使用方式的最終來源。

另請參閱