类在定义成员办法时,局部变量和成员变量能够重名,但此时不能拜访成员变量。为防止这种情景,Java提供了this关键字,示意以后对象,指向调用的对象自身。接下来演示this的实质
1 class Person {
2 public void equals(Person p) {
3 System.out.println(this); // 打印this的地址
4 System.out.println(p); // 打印对象地址
5 if (this == p) // 判断以后对象与this是否相等
6 System.out.println("相等");
7 else
8 System.out.println("不相等");
9 }
10 }
11 public class TestThis {
12 public static void main(String[] args) {
13 Person p1 = new Person();
14 Person p2 = new Person();
15 p1.equals(p1);
16 p1.equals(p2);
17 }
18 }
程序的运行后果如图4.1所示。
图片1
图4.1 例4-1运行后果
在图4.1中,从程序运行后果可发现,关键字this和调用对象p1的值相等,都保留了指向堆内存空间的地址,也就是说,this就是调用对象自身。因而,调用对象p1的this与p2对象不相等。
this关键字在程序中次要有三种用法,上面来别离解说各种用法:
1.应用this调用类中的属性
this关键字能够明确调用类的成员变量,不会与局部变量名发生冲突。接下来演示this调用属性,如例4-2所示。
例4-2 TestThisRefAttr.java
1 class Person {
2 private String name; // 申明姓名公有属性
3 private int age; // 申明年龄公有属性
4 public Person(String name, int age) {
5 this.name = name; // 明确示意为类中的name属性赋值
6 this.age = age; // 明确示意为类中的age属性赋值
7 }
8 public void say() { // 定义显示信息的办法
9 System.out.println("姓名:"+this.name+",年龄:"+this.age);
10 }
11 }
12 public class TestThisRefAttr {
13 public static void main(String[] args) {
14 Person p = new Person("张三", 18);
15 p.say();
16 }
17 }
程序的运行后果如图4.2所示。
图片2
图4.2 例4-2运行后果
例4-2中,构造方法的形参加成员变量同名,应用this明确调用成员变量,防止了与局部变量产生抵触。
2.应用this调用成员办法
this既然能够拜访成员变量,那么也能够拜访成员办法,如例4-3所示。
例4-3 TestThisRefFun.java
1 class Person {
2 private String name; // 申明姓名公有属性
3 private int age; // 申明年龄公有属性
4 public Person(String name, int age) {
5 this.name = name; // 明确示意为类中的name属性赋值
6 this.age = age; // 明确示意为类中的age属性赋值
7 }
8 public void say() { // 定义显示信息的办法
9 System.out.println("姓名:"+thiswww.sangpi.com.name+",年龄:"+this.age);
10 this.log("Person.say"); // this调用成员办法
11 }
12 public void log(String msg) {
13 System.out.println("日志记录:调用"+msg);
14 }
15 }
16 public class TestThisRefFun {
17 public static void main(String[] args) {
18 Person p = new Person("张三", 18);
19 p.say();
20 }
21 }
程序的运行后果如图4.3所示。
图片3
图4.3 例4-3运行后果
例4-3中,在say()办法中明确应用this调用log()成员办法。另外,此处的this能够省略,但倡议不要省略,使代码更加清晰。
3.应用this调用构造方法
构造方法是在实例化时被主动调用的,因而不能间接像调用成员办法一样去调用构造方法,但能够应用this([实参列表])的形式调用其余的构造方法,如例4-4所示。
例4-4 TestThisRefConstructor.java
1 class Person {
2 private String name; // 申明姓名公有属性
3 private int age; // 申明年龄公有属性
4
5 public Person() {
6 System.out.println("调用无参构造方法");
7 }
8 public Person(String name, int age) {
9 this(); // 调用无参构造函数
10 System.out.println("调用有参构造函数");
11 this.name = name; // 明确示意为类中的name属性赋值
12 this.age = age; // 明确示意为类中的age属性赋值
13 }
14 public void say() { // 定义显示信息的办法
15 System.out.println("姓名:"+this.name+",年龄:"+this.age);
16 }
17 }
18 public class TestThisRefConstructor {
19 public static void main(String[] args) {
20 Person p = new Person("张三", 18);
21 p.say();
程序的运行后果如图4.4所示。
图片4
图4.4 例4-4运行后果
例4-4中,实例化对象时,调用了有参构造方法,在该办法中通过this()调用了无参构造方法。因而,运行后果中显示两个结构页游的办法都被调用了。
在应用this调用构造方法时,还需注意:在构造方法中,应用 this调用构造方法的语句必须位于首行,且只能呈现一次,如例4-5所示。
例4-5 TestThisRefConstructor01.java
1 class Person {
2 private String name; // 姓名
3 private int age; // 年龄
4 public Person() {
5 System.out.println("调用无参构造方法");
6 }
7 public Person(String name, int age) {
8 System.out.println("调用有参构造函数");
9 this.name = name;
10 this.age = age;
11 this(); // 调用无参构造函数
12 }
13 public void say() {
14 System.out.println("姓名:"+this.name+",年龄:"+this.age);
15 }
16 }
程序的运行后果如图4.5所示。
图片5
图4.5 例4-5运行后果
在图4.5中,编译报错并提醒“对this的调用必须是结构器中的第一个语句”。因而在应用this()调用构造方法必须位于构造方法的第一行。
另外,this调用构造方法时,肯定要留一个构造方法作为进口,即至多存在一个构造方法不应用this调用其余构造方法,如例4-6所示。
例4-6 TestThisRefConstructor02.java
1 class Person {
2 private String name; // 姓名
3 private int age; // 年龄
4 public Person() {
5 this(null, 0); // 调用有参构造函数
6 System.out.println("调用无参构造方法");
7 }
8 public Person(String name, int age) {
9 this(); // 调用无参构造函数
10 System.out.println("调用有参构造函数");
11 this.name = name;
12 this.age = age;
13 }
14 public void say() {
15 System.out.println("姓名:"+this.name+",年龄:"+this.age);
16 }
17 }
程序的运行后果如图4.6所示。
图片6
图4.6 例4-6运行后果
在图4.6中,编译报错并提醒“递归结构器调用”。因而,在构造方法相互调用时,肯定要预留一个进口,个别将无参构造方法作为进口,即在无参构造方法中不再去调用其余构造方法。