Instrução fixa (referência C#)
The fixed demonstrativo impede que o coletor de lixo realocar uma variável móvel. The fixed demonstrativo só é permitida em um não seguro contexto.Fixed também pode ser usado para criar buffers de dimensionar fixo.
The fixeddemonstrativo define um ponteiro um gerenciado variável e "fixa" ou variável durante a execução da demonstrativo. Sem fixed, ponteiros para variáveis gerenciado móveis seria de pouco uso desde lixo coleção pode realocar as variáveis de forma imprevisível. O compilador translation from VPE for Csharp só permite atribuir um ponteiro para uma variável gerenciada em um fixed demonstrativo.
unsafe static void TestMethod()
{
// assume class Point { public int x, y; }
// pt is a managed variable, subject to garbage collection.
Point pt = new Point();
// Using fixed allows the address of pt members to be
// taken, and "pins" pt so it isn't relocated.
fixed (int* p = &pt.x)
{
*p = 1;
}
}
Você pode inicializar um ponteiro com o endereço de uma matriz ou uma seqüência de caracteres:
unsafe void Test2()
{
Point point = new Point();
double[] arr = { 0, 1.5, 2.3, 3.4, 4.0, 5.9 };
string str = "Hello World";
fixed (double* p = arr) { /*...*/ } // equivalent to p = &arr[0]
fixed (char* p = str) { /*...*/ } // equivalent to p = &str[0]
fixed (int* p1 = &point.x)
{
fixed (double* p2 = &arr[5])
{
// Do something with p1 and p2.
}
}
}
Você pode inicializar várias ponteiros, desde que eles sejam todos do mesmo tipo:
fixed (byte* ps = srcarray, pd = dstarray) {...}
Para inicializar os ponteiros de tipo diferente, simplesmente aninhar fixed instruções:
fixed (int* p1 = &point.x)
{
fixed (double* p2 = &arr[5])
{
// Do something with p1 and p2.
}
}
Após o código na demonstrativo é executado, qualquer variáveis fixados são lixo desagregado e está sujeito à coleção.Portanto, não apontam para essas variáveis fora o fixed demonstrativo.
Observação: |
---|
Ponteiros inicializados em instruções fixas não podem ser modificados. |
No modo não seguro, é possível alocar memória na pilha, onde ele não é sujeita a coleta de lixo e, portanto, não precisa ser fixado.Para obter mais informações, consulte stackalloc.
Exemplo
class Point
{
public int x, y;
}
class FixedTest2
{
// Unsafe method: takes a pointer to an int.
unsafe static void SquarePtrParam (int* p)
{
*p *= *p;
}
unsafe static void Main()
{
Point pt = new Point();
pt.x = 5;
pt.y = 6;
// Pin pt in place:
fixed (int* p = &pt.x)
{
SquarePtrParam (p);
}
// pt now unpinned
Console.WriteLine ("{0} {1}", pt.x, pt.y);
}
}
/*
Output:
25 6
*/
Especificação da linguagem C#
Para obter mais informações, consulte as seções a seguir no Especificação da linguagem C#:
18.3 Variáveis fixas e móveis
18.6 A demonstrativo fixed
Consulte também
Conceitos
Referência
Buffers de dimensionar fixo (guia de programação translation from VPE for Csharp)