Compartilhar via


unsafe (Referência de C#)

A unsafe palavra-chave indica um contexto não seguro, que é necessário para qualquer operação que envolva ponteiros. Para obter mais informações, consulte Código e ponteiros não seguros.

Você pode usar o unsafe modificador na declaração de um tipo ou membro. A extensão textual inteira do tipo ou membro é, portanto, considerada um contexto não seguro. Por exemplo, o seguinte é um método declarado com o unsafe modificador:

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

O escopo do contexto não seguro se estende da lista de parâmetros até o final do método, de modo que os ponteiros também podem ser usados na lista de parâmetros:

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

Você também pode usar um bloco não seguro para habilitar o uso de um código não seguro dentro desse bloco. Por exemplo:

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

Para compilar código não seguro, você deve especificar a opção do compilador AllowUnsafeBlocks . O código não seguro não é verificável pelo common language runtime.

Exemplo

// 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

Especificação da linguagem C#

Para obter mais informações, consulte código não seguro na Especificação da Linguagem C#. A especificação de idioma é a fonte definitiva para a sintaxe e o uso de C#.

Consulte também