unsafe (Referência de C#)unsafe (C# Reference)

A palavra-chave unsafe denota um contexto inseguro, que é necessário para qualquer operação que envolva ponteiros.The unsafe keyword denotes an unsafe context, which is required for any operation involving pointers. Para obter mais informações, consulte Código não seguro e ponteiros.For more information, see Unsafe Code and Pointers.

Você pode usar o modificador unsafe na declaração de um tipo ou membro.You can use the unsafe modifier in the declaration of a type or a member. Toda a extensão textual do tipo ou membro é, portanto, considerada um contexto inseguro.The entire textual extent of the type or member is therefore considered an unsafe context. Por exemplo, a seguir está um método declarado com o modificador unsafe:For example, the following is a method declared with the unsafe modifier:

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

O escopo do contexto inseguro se estende da lista de parâmetros até o final do método, portanto, os ponteiros também podem ser usados na lista de parâmetros:The scope of the unsafe context extends from the parameter list to the end of the method, so pointers can also be used in the parameter list:

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.You can also use an unsafe block to enable the use of an unsafe code inside this block. Por exemplo:For example:

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

Para compilar o código não seguro, você deve especificar a opção do compilador /unsafe.To compile unsafe code, you must specify the /unsafe compiler option. O código não seguro não é verificável pelo Common Language Runtime.Unsafe code is not verifiable by the common language runtime.

ExemploExample

// 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#C# Language Specification

Para obter mais informações, consulte a Especificação da linguagem C#.For more information, see the C# Language Specification. A especificação da linguagem é a fonte definitiva para a sintaxe e o uso de C#.The language specification is the definitive source for C# syntax and usage.

Consulte tambémSee Also