Share via


Passando parâmetros deTipo (guia de programação de C#) a referência-

Uma variável de um tipo de referência não contém seus dados diretamente. ele contém uma referência a seus dados. Quando você passa um parâmetro de tipo de referência por valor, é possível alterar os dados apontados por referência, como, por exemplo, o valor de um membro de classe. No entanto, você não pode alterar o valor da referência propriamente dito; ou seja, é possível usar a mesma referência alocar memória para uma nova classe e ainda persistem fora do bloco. Para isso, passar o parâmetro usando a ref ou check-out palavra-chave. Para simplificar, os exemplos seguintes usam ref.

Exemplo

O exemplo a seguir demonstra a passar um parâmetro de tipo de referência, arr, por valor, para um método, Change. Porque o parâmetro é uma referência a arr, é possível alterar os valores dos elementos da matriz. No entanto, a tentativa de reatribuir o parâmetro para um local de memória diferentes só funciona dentro do método e não afeta a variável original, arr.

class PassingRefByVal 
{
    static void Change(int[] pArray)
    {
        pArray[0] = 888;  // This change affects the original element.
        pArray = new int[5] {-3, -1, -2, -3, -4};   // This change is local.
        System.Console.WriteLine("Inside the method, the first element is: {0}", pArray[0]);
    }

    static void Main() 
    {
        int[] arr = {1, 4, 5};
        System.Console.WriteLine("Inside Main, before calling the method, the first element is: {0}", arr [0]);

        Change(arr);
        System.Console.WriteLine("Inside Main, after calling the method, the first element is: {0}", arr [0]);
    }
}
/* Output:
    Inside Main, before calling the method, the first element is: 1
    Inside the method, the first element is: -3
    Inside Main, after calling the method, the first element is: 888
*/

No exemplo anterior, a matriz, arr, que é um tipo de referência é passado para o método sem o ref parâmetro. Nesse caso, uma cópia de referência, que aponta para arr, que é passado para o método. A saída mostra que é possível que o método alterar o conteúdo de um elemento de matriz, nesse caso, de 1 para 888. No entanto, alocar uma nova parte da memória usando o nova operador dentro do Change método torna a variável pArray referência uma nova matriz. Portanto, quaisquer alterações depois que isso não afetará a matriz original, arr, que é criado dentro de Main. Na verdade, duas matrizes são criadas neste exemplo, um interno Main e um dentro do Change método.

Este exemplo é o mesmo do exemplo anterior, exceto o ref palavra-chave no cabeçalho do método e chamada. Quaisquer alterações que ocorrem no método afetará as variáveis originais no programa de chamada.

class PassingRefByRef 
{
    static void Change(ref int[] pArray)
    {
        // Both of the following changes will affect the original variables:
        pArray[0] = 888;
        pArray = new int[5] {-3, -1, -2, -3, -4};
        System.Console.WriteLine("Inside the method, the first element is: {0}", pArray[0]);
    }

    static void Main() 
    {
        int[] arr = {1, 4, 5};
        System.Console.WriteLine("Inside Main, before calling the method, the first element is: {0}", arr[0]);

        Change(ref arr);
        System.Console.WriteLine("Inside Main, after calling the method, the first element is: {0}", arr[0]);
    }
}
/* Output:
    Inside Main, before calling the method, the first element is: 1
    Inside the method, the first element is: -3
    Inside Main, after calling the method, the first element is: -3
*/

Todas as alterações que ocorrem dentro do método afetam a matriz original em Main. Na verdade, a matriz original é realocada em usando o new operador. Assim, depois de chamar o Change método, qualquer referência a arr aponta para a matriz de cinco elementos, o que é criada na Change método.

Seqüências de troca é um bom exemplo de passar parâmetros de tipo de referência por referência. No exemplo, duas seqüências de caracteres, str1 e str2, que são inicializados em Main e passado para o SwapStrings método como parâmetros modificado pela ref palavra-chave. As duas seqüências são trocadas dentro do método e interior Main como bem.

 class SwappingStrings
 {
     static void SwapStrings(ref string s1, ref string s2)
     // The string parameter is passed by reference.
     // Any changes on parameters will affect the original variables.
     {
         string temp = s1;
         s1 = s2;
         s2 = temp;
         System.Console.WriteLine("Inside the method: {0} {1}", s1, s2);
     }

     static void Main()
     {
         string str1 = "John";
         string str2 = "Smith";
         System.Console.WriteLine("Inside Main, before swapping: {0} {1}", str1, str2);

         SwapStrings(ref str1, ref str2);   // Passing strings by reference
         System.Console.WriteLine("Inside Main, after swapping: {0} {1}", str1, str2);
     }
 }
 /* Output:
     Inside Main, before swapping: John Smith
     Inside the method: Smith John
     Inside Main, after swapping: Smith John
*/

Neste exemplo, os parâmetros precisam ser passados por referência para afetar as variáveis no programa de chamada. Se você remover o ref palavra-chave a partir do cabeçalho do método e a chamada do método, nenhuma alteração ocorrerá no programa de chamada.

Para obter mais informações sobre seqüências de caracteres, consulte seqüência de caracteres.

Consulte também

Referência

Passando parâmetros (guia de programação de C#)

Passando o uso de Arrays ref e out (guia de programação C#)

REF (referência de C#)

Reference Types (C# Reference)

Conceitos

C# Programming Guide