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#.