this关键字总是指向调用该方法的对象。下面举例子说明一下this的作用
1.不使用this的例子
public class Dog {
public void jump(){
System.out.println("正在执行jump方法");
}
public void run(){
Dog d =new Dog();
d.jump();
System.out.println("正在执行run方法");
}
}
测试类
public class DogTest {
public static void main(String[] args){
Dog dog =new Dog();
dog.run();
}
}
我们用图图示分析下上面代码的过程
这段程序产生两个dog对象,其实第二个Dog对象完全没有必要创建,因为当调用run方法时,调用者一定会提供一个Dog对象的,在run方法中完全可以使用已经存在的Dog对象。
this可以代表任何对象,当this出现在某个方法体中时,this代表的对象不确定,谁调用这个方法,this就代表谁。但是类型是确定的,就是当前类
上面的代码可以这样改:
public class Dog {
public void jump(){
System.out.println("正在执行jump方法");
}
public void run(){
this.jump();
System.out.println("正在执行run方法");
}
}
这种方法更符合实际意义,前面那种方法,意味着一个Dog对象的run方法需要依赖与另一个Dog对象的jump方法,不符合逻辑。使用this的方法,当一个Dog对象调用run方法时,润方法依赖自己的jump方法
补充一点:同一个类的方法调用另外一个方法时,如果被调用方法是普通方法,则使用this作为调用者,如果被调用方法是静态方法,默认使用类作为调用者。
举例:
public class PersonTest {
public void info()
{
System.out.println("正在执行info方法");
}
public static void main(String[] args){
info();
}
这种静态方法调用非静态方法是不对的,正确的写法是
public class PersonTest {
public void info()
{
System.out.println("正在执行info方法");
}
public static void main(String[] args){
new PersonTest().info();
}
}
还有例子:
public class PersonTest {
int foo;
public void info()
{
this.foo=6;//
}
public static void main(String[] args){
new PersonTest().foo=6;;
}
}
2.super
当子类覆盖了父类方法后,子类的对象将无法访问父类中被覆盖的方法,但可以在子类方法中调用父类中被覆盖的方法,使用super(被覆盖的是实例方法)或者父类类名(被覆盖的是类方法)作为调用者来调用父类中被覆盖的方法。同this一样,super也不能出现在static修饰的方法中。