this (справочник по C#)

Ключевое слово this ссылается на текущий экземпляр класса, а также используется в качестве модификатора первого параметра метода расширения.

Примечание.

В этой статье рассматривается использование this с экземплярами класса. Дополнительные сведения об использовании этого ключевого слова в методах расширения см. в разделе Методы расширения.

Ниже перечислены наиболее частые способы использования this.

  • Для квалификации элементов, скрытых одинаковыми именами, например:

    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;
        }
    }
    
  • Для передачи другим методам объекта в качестве параметра, например:

    CalcTax(this);
    
  • Чтобы объявить индексаторы, например:

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

У статических функций-членов нет указателя this, так как они существуют только на уровне класса и не являются частями объектов. Использование this в статическом методе приводит к ошибке.

Пример

В этом примере this используется для квалификации членов класса Employee, name и alias, которые скрыты одинаковыми именами. Это ключевое слово также используется для передачи объекта в метод CalcTax, который принадлежит другому классу.

class Employee
{
    private string name;
    private string alias;
    private decimal salary = 3000.00m;

    // 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: {0}\nAlias: {1}", name, alias);
        // Passing the object to the CalcTax method by using this:
        Console.WriteLine("Taxes: {0:C}", Tax.CalcTax(this));
    }

    public decimal Salary
    {
        get { return salary; }
    }
}

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

class MainClass
{
    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
 */

Спецификация языка C#

Дополнительные сведения см. в спецификации языка C#. Спецификация языка является предписывающим источником информации о синтаксисе и использовании языка C#.

См. также