Share via


unsafe (Referência de C#)

O unsafe palavra-chave denota um contexto sem segurança, o que é necessário para qualquer operação que envolva ponteiros. Para obter mais informações, consulte Código não seguro e ponteiros (Guia de Programação em C#).

Você pode usar o unsafe modificador na declaração de um tipo ou membro. Toda a extensão textual do tipo ou membro, portanto, é considerada um contexto sem segurança. 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.
}

Amplia o escopo do contexto não seguro na lista de parâmetro ao final do método, para 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 permitir o uso de um código não seguro dentro desse bloco. Por exemplo:

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

Para compilar o código não seguro, você deve especificar o /unsafe opção de compilador. 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 a Especificação da linguagem C#. A especificação da linguagem é a fonte definitiva para a sintaxe e o uso de C#.

Consulte também

Referência

Palavras-chave C#

Instrução fixed (Referência de C#)

Código não seguro e ponteiros (Guia de Programação em C#)

Buffers de tamanho fixo (Guia de Programação em C#)

Conceitos

Guia de Programação em C#

Outros recursos

Referência de C#