多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
# this(C# 参考) **this** 关键字引用类的当前实例,还可用作扩展方法的第一个参数的修饰符。 | ![](https://box.kancloud.cn/2016-01-31_56adb62c1380a.jpg) 注意 | | :-- | | 本文讨论对类实例使用 **this**。有关其在扩展方法中使用的更多信息,请参见[扩展方法(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/bb383977.aspx)。 | 以下是 **this** 的常用用途: * 限定被相似的名称隐藏的成员,例如: ``` public Employee(string name, string alias) { // Use this to qualify the fields, name and alias: 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# 语言规范](https://msdn.microsoft.com/zh-cn/library/ms228593.aspx)。该语言规范是 C# 语法和用法的权威资料。 ## 请参阅 [C# 参考](https://msdn.microsoft.com/zh-cn/library/618ayhy6.aspx) [C# 编程指南](https://msdn.microsoft.com/zh-cn/library/67ef8sbd.aspx) [C# 关键字](https://msdn.microsoft.com/zh-cn/library/x53a06bb.aspx) [base(C# 参考)](https://msdn.microsoft.com/zh-cn/library/hfw7t1ce.aspx) [方法(C# 编程指南)](https://msdn.microsoft.com/zh-cn/library/ms173114.aspx)