não seguros (C# Reference)
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 Não seguro código e ponteiros (guia de programação do 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 Especificação de linguagem do C# A especificação da linguagem é a fonte definitiva para a sintaxe e o uso da linguagem C#.
Consulte também
Referência
Instrução fixed (referência de C#)
Não seguro código e ponteiros (guia de programação do C#)
Buffers de tamanho fixo (guia de programação do C#)