this (Referenční dokumentace jazyka C#)

Klíčové this slovo odkazuje na aktuální instanci třídy a používá se také jako modifikátor prvního parametru metody rozšíření.

Poznámka:

Tento článek popisuje použití this s instancemi třídy. Další informace o jeho použití v rozšiřujících metodách naleznete v tématu Metody rozšíření.

Toto jsou běžné použití this:

  • Pokud chcete kvalifikovat členy skryté podobnými názvy, například:

    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;
        }
    }
    
  • Předání objektu jako parametru jiným metodám, například:

    CalcTax(this);
    
  • Deklarace indexerů, například:

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

Statické členské funkce, protože existují na úrovni třídy, a ne jako součást objektu, nemají this ukazatel. Jedná se o chybu odkazující na this statickou metodu.

Příklad

V tomto příkladu thisEmployee se používá k kvalifikaci členů name třídy a alias, které jsou skryty podobnými názvy. Slouží také k předání objektu metodě CalcTax, která patří do jiné třídy.

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

specifikace jazyka C#

Další informace najdete v tématu Specifikace jazyka C#. Specifikace jazyka je úplným a rozhodujícím zdrojem pro syntaxi a použití jazyka C#.

Viz také