一个对象对应一个this,this是一个变量,是一个引用。this保存当前对象的内存地址指向自身。 super关键字代表的就是“当前对象”的那部分父类型特征。
this和super出现在实例方法和构造方法中。this的语法是:“this.”、“this()”、super的语法是:“super.”、“super()”。this和super不能使用在静态方法中。this.在区分局部变量和实例变量时不能省略;super.在“父类中有,子类中又有,如果在子类中访问‘父类的特征’时”,super.不能省略。
this()和super()都只会出现在构造方法的第一行,前者是通过当前的构造方法去调用”本类“中的其它构造方法,目的是实现代码复用。后者是通过当前的构造方法去调用”父类“中的构造方法,目的是创建子类对象时先初始化父类型特征。
当一个构造方法第一行既没有this()又没有super()的话,系统默认会有一个super()
public class Super {
public static void main(String[] args) {
C c = new C();
}
}
class A {
//这个无参构造方法是B类的父类--A类的无参构造器,所以最后执行这个方法的语句
//这个类似于栈,最后调用的最先出栈,即最先执行,故最先输出 “1”
public A() {
System.out.println("A类的无参构造方法执行");
}
}
class B extends A {
public B() {
System.out.println("B类的无参构造方法执行");
}
public B(String name) {
//super(name); 在B类中找带String参数的构造方法,所以第四个执行这条语句
//super() 其实这块也有super,只不过是系统默认分配,看不到而已这块的super找它父类的无参构造方法
System.out.println("B类的String类参数构造方法执行");
}
}
class C extends B {
public C () {
this("zhangsan");
// new C 时先执行这条语句
System.out.println("C类的无参构造方法执行");
}
public C (String name) {
// this("zhangsan");会在C类中找带String参数的构造方法,所以第二个执行这条语句
this(name,20);
System.out.println("C类的String类参数构造方法执行");
}
public C (String name, int age) {
// this(name,20);会在C类中找带String,int参数的构造方法,所以第三个执行这条语句
super(name);
// 找它父类的方法 在B类中
System.out.println("C类的String类和int类参数构造方法执行");
}
}
super(实际参数) 【调用父类的构造方法】 super.方法名(实际参数)【访问父类方法】