Partilhar via


(referência C#) não seguros

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

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

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

Estende o escopo de contexto sem segurança da lista de parâmetro até o participante do método, para que ponteiros também possam 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 /unsafeopção do compilador .Código não seguro não é verificável common linguagem tempo de execução.

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 as seções a seguir no Especificação da linguagem C#:

  • 18 código não seguro

Consulte também

Conceitos

Guia de Programação C#

Referência

Palavras-chave C#

Instrução fixa (referência C#)

Não seguro código e ponteiros (guia de programação C#)

Buffers de dimensionar fixo (guia de programação translation from VPE for Csharp)

Outros recursos

Referência C#