Поделиться через


Ключевое слово

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

Примечание.

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

Ниже приведены распространенные способы использования 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 => array[param];
        set => array[param] = value;
    }
    

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

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

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
 */

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

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

См. также