1、super是一个关键字,全部小写。
 2、super 和 this 对比着学习。
 this:
 this 能出现在实例方法和构造方法中。
 this 的语法是:“this.”、“this()”
 this 不能使用在静态方法中。
 this. 大部分情况下是可以省略的。
 this. 什么时候不能省略呢?在区分局部变量和实例变量的时候不能省略。
 public void setName(String name){
 this.name = name;
 }
 this() 只能出现在构造方法第一行,通过当前的构造方法去调用“本类”中其它的构造方法,目的是:代码复用。
 super:
 super 能出现在实例方法和构造方法中。
 super 的语法是:“super.”、“super()”
 super 不能使用在静态方法中。
 super. 大部分情况下是可以省略的。
 super. 什么时候不能省略呢?
 父类和子类中有同名属性,或者说有同样的方法,想在子类中访问父类,super. 不能省略。
 super() 只能出现在构造方法第一行,通过当前的构造方法去调用“父类”中的构造方法,
 目的是:创建子类对象的时候,先初始化父类型特征。
 3、super()
 表示通过子类的构造方法调用父类的构造方法。
 模拟现实世界中的这种场景:要想长出西瓜,需要先有瓜苗。
 4、重要的结论:
 当一个构造方法第一行:
 既没有 this(),又没有 super() 的话,默认会有一个 super();
 表示通过当前子类的构造方法调用父类的无参数构造方法。
 所以必须保证父类的无参数构造方法是存在的。
 5、注意:
 this() 和 super() 不能共存,它们都是只能出现在构造方法第一行。
 6、无论是怎么弄,父类的构造方法是一定会执行的。(百分百的)
在java语言中不管是 new 什么对象,最后根的 Object 类的无参数构造方法一定会执行。
 (Object 类中的无参数构造方法是处于“栈顶部”)
 栈顶的特点:
 最后调用,但最先执行结束。
 后进先出原则。
 要注意:
 以后写代码的时候,一个类的无参数构造方法还是建议大家手动的写出来。
 如果无参数构造方法丢失的话,可能会影响到“子类对象的构建”。
私有的属性,只能在本类中访问。可以通过其它方式间接访问。
super代表的是“当前对象(this)”的“父类型特征”。
1、举个例子:在恰当的时间使用:super(实际参数列表);
 2、注意:在构造方法执行过程中一连串调用了父类的构造方法,父类的构造方法又继续向下调用它的父类的
 构造方法,但是实际上对象只创建了一个。
 3、思考:“super(实参)”到底是干啥的?
 super(实参) 的作用是:初始化当前对象的父类型特征。并不是创建对象。实际上对象只创建了1个。
 4、super 关键字代表什么呀?
 super 关键字代表的就是“当前对象”的那部分父类型特征。
 我继承了我母亲的一部分特征:
 例如:眼睛、皮肤等。
 super 代表的就是“眼睛、皮肤等”。
 “眼睛、皮肤等”虽然是继承了母亲的,但这部分是在我身上呢。(我和我父亲不像)
1、“this.”和“super.”大部分情况下都是可以省略的。
 2、this. 什么时候不能省略?
 public void setName(String name){
 this.name = name;
 }
 3、super. 什么时候不能省略?
 父中有,子中又有,如果想在子中访问“父类的特征”,super. 不能省略。
 在父和子中有同名的属性,或者说有相同的方法,如果此时现在子类中访问父中的数据,必须使用“super.”加以区分。
java是怎么来区分子类和父类的同名属性的?
 this.name:当前对象的 name 属性
 super.name:当前对象的父类型特征中的 name 属性。
输出“引用”的时候,会自动调用引用的 toString() 方法。this 和 this.toString() 相同。
super 不是引用。super 也不保存内存地址,super 也不指向任何对象。
 super 只是代表当前对象内部的那一块父类型的特征。
super 不仅可以访问属性,也可以访问方法。
super.属性名 访问父类的属性
 super.方法名(实参) 访问父类的方法
 super(实参) 调用父类的构造方法
System.exit(0); 退出JVM虚拟机