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# の構文と使用法の決定的なソースです。
こちらも参照ください
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET