次の方法で共有


unsafe (C# リファレンス)

unsafe キーワードは、ポインターを含む操作に必要な安全でないコンテキストを表します。 詳細については、「 安全でないコードとポインター」を参照してください。

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# の構文と使用法の決定的なソースです。

こちらも参照ください