Compartilhar via


A palavra-chave

A this palavra-chave refere-se à instância atual da classe e também é usada como um modificador do primeiro parâmetro de um método de extensão.

Observação

Este artigo discute o uso de this com instâncias de classe. Para obter mais informações sobre seu uso em métodos de extensão, consulte a extension palavra-chave.

Veja a seguir os usos comuns de this:

  • Para qualificar membros ocultados por nomes semelhantes, por exemplo:

    public class Employee
    {
        private string alias;
        private string name;
    
        public Employee(string name, string alias)
        {
            // Use this to qualify the members of the class
            // instead of the constructor parameters.
            this.name = name;
            this.alias = alias;
        }
    }
    
  • Para passar um objeto como um parâmetro para outros métodos, por exemplo:

    CalcTax(this);
    
  • Para declarar indexadores, por exemplo:

    public int this[int param]
    {
        get => array[param];
        set => array[param] = value;
    }
    

As funções de membro estático, porque existem no nível da classe e não como parte de um objeto, não têm um this ponteiro. É um erro referir-se a this em um método estático.

Neste exemplo, os parâmetros namee alias ocultam campos com os mesmos nomes. A this palavra-chave qualifica essas variáveis como Employee membros de classe. A this palavra-chave também especifica o objeto para o método CalcTax, que pertence a outra classe.

class Employee
{
    private string name;
    private string alias;

    // Constructor:
    public Employee(string name, string alias)
    {
        // Use this to qualify the fields, name and alias:
        this.name = name;
        this.alias = alias;
    }

    // Printing method:
    public void printEmployee()
    {
        Console.WriteLine($"""
        Name: {name}
        Alias: {alias}
        """);
        // Passing the object to the CalcTax method by using this:
        Console.WriteLine($"Taxes: {Tax.CalcTax(this):C}");
    }

    public decimal Salary { get; } = 3000.00m;
}

class Tax
{
    public static decimal CalcTax(Employee E)=> 0.08m * E.Salary;
}

class Program
{
    static void Main()
    {
        // Create objects:
        Employee E1 = new Employee("Mingda Pan", "mpan");

        // Display results:
        E1.printEmployee();
    }
}
/*
Output:
    Name: Mingda Pan
    Alias: mpan
    Taxes: $240.00
 */

Especificação da linguagem C#

Para obter mais informações, consulte a Especificação da Linguagem C# . A especificação de idioma é a fonte definitiva para a sintaxe e o uso de C#.

Consulte também