java中this关键字

一:Java中this关键字的3个应用

  1. this调用本类中的属性,也就是类中的成员变量
  2. this调用本类中的其他方法
  3. this调用本类中的其他构造方法,调用时要放在构造方法的首行
public class Leaf {

	int i = 0;
	public Leaf(int i) {
		this.i = i;
	}
	public Leaf(){
		this(2);
	}
	Leaf increament(){
		i++;
		return this;
	}
	void print(){
		System.out.println("i="+i);
	}

	public static void main(String[] args) {
		Leaf leaf1 = new Leaf(100);
		Leaf leaf2 = new Leaf();
		leaf1.increament().increament().print();
		leaf2.increament().print();
	}
}

1.引用成员变量

       

       上述代码中有一个成员变量i,同时在构造方法中有一个形参名字也是i,然后在方法中将形参i的值传递给成员变量i

虽然我们可以看明白这个代码的含义,但是作为Java编译器它是怎么判断的呢?到底是将形式参数i的值传递给成员变量i,还是反过来将成员变量i的值传递给形参i呢?即,两个变量名字如果相同的话,那么Java如何判断使用哪个变量?

        此时this这个关键字就起到作用了。this这个关键字其代表的就是对象中的成员变量或者方法。也就是说,如果在某个变量前面加上一个this关键字,其指的就是这个对象的成员变量或者方法,而不是指成员方法的形参或者局部变量。为此在上面这个代码中,this.i代表的就是对象中的成员变量,又叫做对象的属性,而后面的i则是方法的形式参数,代码this.i=i就是将形参的值传递给成员变量。这就是上面这个代码的具体含义。

一般情况下,在Java语言中引用成员变量或者成员方法都是以对象名.成员变量或者对象名.成员方法的形式。不过有些程序员即使在没有相同变量的时候,也喜欢使用this.成员变量的形式来引用变量,这主要是从便于代码的阅读考虑的。一看到这个this关键字就知道现在引用的变量是成员变量或者成员方法,而不是局部变量。这无形中就提高了代码的阅读性。不过话说回来,这是this关键字在Java语言中的最简单的应用。从这个应用中,我们可以看出this关键字其代表的就是对象的名字。

       其实如果是局部变量的话,也是相同的道理。如在上面的代码中,i不是形参,而是一个局部变量。此时Java也会遇到相同的疑惑,即变量名i代表的到底是局部变量还是形参?i=i到底代表的是什么含义?根据局部变量的作用域,在方法内部,如果局部变量与成员变量同名的话,那么是以局部变量为准。可是在i=i这个赋值语句中,将局部变量的值赋值给自己,显然并不是很合适。根据代码的含义,本来的意思应该是将局部变量赋值给成员变量。为了更清晰的表达这个含义,为此最好采用如下的书写格式this.i=i。这里的this关键字含义就是对象名leaf,为此this.i就表示leaf.name。

2.调用类的构造方法


this关键字除了可以调用成员变量之外,还可以调用构造方法。列如上图的this(2)。

知识点1:在一个Java类中,其方法可以分为成员方法和构造方法两种。

构造方法:构造方法是一个与类同名的方法,在Java类中必须存在一个构造方法。如果在代码中没有显示的体现构造方法的话,那么编译器在编译的时候会自动添加一个没有形参的构造方法。

知识点2:构造方法和普通方法的区别

  1. 构造方法一律是没有返回值的,而且也不用void关键字来说明这个构造方法没有返回值。而普通的方法可以有返回值、也可以没有返回值,程序员可以根据自己的需要来定义。不过如果普通的方法没有返回值的话,那么一定要在方法定义的时候采用void关键字来进行说明。
  2. 构造方法的名字有严格的要求,即必须与类的名字相同。也就是说,Java编译器发现有个方法与类的名字相同才把其当作构造方法来对待。而对于普通方法的话,则要求不能够与类的名字相同,而且多个成员方法不能够采用相同的名字。在一个类中可以存在多个构造方法,这些构造方法都采用相同的名字,只是形式参数不同。Java语言就凭形式参数不同来判断调用那个构造方法。

在上面这段代码中,定义了两个构造方法,一个带参数,一个没有带参数。在第二个没有带参数的构造方法中,使用了this(2)这句代码,这句代码表示什么含义呢?

如果一个类中有多个构造方法,因为其名字都相同,跟类名一致,那么这个this到底是调用哪个构造方法呢?其实,这跟采用其他方法引用构造方法一样,都是通过形式参数来调用构造方法的。如上例中,this关键字后面加上了一个参数,那么就表示其引用的是带参数的构造方法。如果现在有三个构造方法,分别为不带参数、带一个参数、带两个参数。那么Java编译器会根据所传递的参数数量的不同,来判断该调用哪个构造方法。从上面示例中可以看出,this关键字不仅可以用来引用成员变量,而且还可以用来引用构造方法。

不过如果要使用这种方式来调用构造方法的话,有一个语法上的限制。一般来说,利用this关键字来调用构造方法,只有在无参数构造方法中第一句使用this调用有参数的构造方法。否则的话,翻译的时候,就会有错误信息。这跟引用成员变量不同。如果引用成员变量的话,this关键字是没有位置上的限制的。如果不熟悉这个限制的话,那么还是老老实实的采用传统的构造方法调用方式为好。虽然比较麻烦,但是至少不会出错。

3.返回对象的值


如上述代码,可以使用return this,来返回某个类的引用。此时这个this关键字就是代表类的名称,即return leaf。

二:Java运行时数据存储机制

我们根据上面的代码再练习一下数据存储机制:

public static void main(String[] args) {
		Leaf leaf1 = new Leaf(100);
		Leaf leaf2 = new Leaf();
		leaf1.increament().increament().print();
		leaf2.increament().print();
	}

this这个关键字,我们可以理解成this指向对象自己


第1行:



第2行:


第3行:


(1)我们先分析leaf1.increament() 。该对象的i的值+1,increament()方法里return this,在栈内存里新开一块内存,它指向的还是它本身。leaf1.increament()执行完如下图:


(2)再分析leaf1.increament().increament();i的值+1,return this,在栈内存里新开一块内存,它指向的还是它本身。执行完如下图所示。临时内存消失,引用也消失


(3)leaf1.increament().increament().print();打印出来

第4行:同理,如下图所示。后续就是临时内存消失,引用也消失。


执行完后:


打印出来结果:

i=102
i=3

你可能感兴趣的:(java基础)