本章节目标:
掌握super都可以用在哪里?理解super在内存方面的存储位置。掌握怎么通过子类的构造方法调用父类的构造方法。super什么时候可以省略,什么时候不能省略?
● this是一个引用,保存内存地址指向自己。
● this出现在实例方法中,谁调用这个实例方法,this就代表谁,this代表当前正在执行这个动作的对象。
● this不能出现在静态方法中。
● this大部分情况下可以省略,在方法中区分实例变量和局部变量的时候不能省略。
●“this(实际参数列表)”出现在构造方法第一行,通过当前的构造方法去调用本类当中其它的构造方法。
严格来说,super其实并不是一个引用,它只是一个关键字,super代表了当前对象中从父类继承过来的那部分特征。this指向一个独立的对象,super并不是指向某个“独立”的对象,假设张大明是父亲,张小明是儿子,有这样一句话:大家都说张小明的眼睛、鼻子和父亲的很像。那么也就是说儿子继承了父亲的眼睛和鼻子特征,那么眼睛和鼻子肯定最终还是长在儿子的身上。假设this指向张小明,那么super就代表张小明身上的眼睛和鼻子。换句话说super其实是this的一部分。如下图所示:张大明和张小明其实是两个独立的对象,两个对象内存方面没有联系,super只是代表张小明对象身上的眼睛和鼻子,因为这个是从父类中继承过来的,在内存方面使用了super关键字进行了标记,对于下图来说“this.眼睛”和“super.眼睛”都是访问的同一块内存空间。
图14-1:super内存图
● super和this都可以使用在实例方法当中。
● super不能使用在静态方法当中,因为super代表了当前对象上的父类型特征,静态方法中没有this,肯定也是不能使用super的。
● super也有这种用法:“super(实际参数列表);”,这种用法是通过当前的构造方法调用父类的构造方法。
接下来,我们来测试一下:
public class SuperTest01 extends Object{
//实例方法
public void doSome(){
System.out.println(this);
System.out.println(super);
}
}
编译报错了:
图14-2:this可以单独输出,super不能
通过以上的测试,可以看出this是可以单独使用的引用,但super无法输出,编译器提示super要使用必须是“super.xxx”,显然super并不指向独立的对象,并不是保存某个对象的内存地址。
再来看另外的一个测试:
public class SuperTest02 extends Object{
//静态方法
public static void doSome(){
System.out.println(this);
System.out.println(super.toString());
}
}
编译报错了:
图14-3:this和super都不能使用在静态方法中
通过以上的测试,可以看出this和super都是无法使用在静态方法当中的。