这是我学习慕课网Java课程的笔记,原视频链接为:http://www.imooc.com/learn/124
3-1 Java 中的继承
★ 概念:继承是类与类的一种关系,是一种 “is
a” 的关系
图:继承关系——狗 和 动物
注:Java 中的继承是单继承,即一个类仅仅有一个父类
★ 优点
● 子类拥有父类的全部属性和方法,但假设有private修饰,则子类不能使用该属性或方法
● 实现代码复用
★ 语法规则
class 子类 extends 父类
例:class Dog extends Animal{
……
}
Eclipse中。在创建类时。能够在 Superclass 中选择父类
自己主动生成:
3-2 Java 中的方法重写
★ 概念
假设子类对继承父类的方法不惬意,是能够重写父类继承的方法的,当调用方法时会优先调用子类的方法。
★ 语法规则
a.返回值类型
b.方法名
c.參数类型及个数
都要与父类继承的方法同样,才叫方法的重写
★ 实例:狗
和动物
图:父类——动物
图:子类——狗
图:測试类
执行结果: 年龄:1狗是能够会吃东西
3-3 Java 中的继承初始化顺序
★ 继承的初始化顺序
a. 先初始化父类再初始化子类
b. 先运行初始化对象中属性,再运行构造方法中的初始化
★
实例一:验证先初始化父类再初始化子类
图:父类——动物
图:子类——狗
图:測试类——调用eat()方法
执行结果:
★
实例二:验证先运行 初始化对象中的属性,再运行构造方法中的初始化
图:父类——动物
图:測试类——调用eat()方法
执行结果:
★ 总结
3-4 Java 中的 final 的使用
使用finalkeyword做标识,有“终于的”含义。即 不可改动。不可变化
★ final能够修饰类、方法、属性和变量
● final修饰类 —— 该类不同意被继承
● final修饰方法
—— 该方法不同意被覆盖(重写)
● final修饰属性
—— 该类的属性不会进行隐式的初始化(类的初始化属性必须有值),或在构造方法中赋值(但仅仅能选其一)
且不能在其它地方改动属性的值。
● final修饰变量
—— 该变量的值仅仅能赋一次值,即变为 常量
3-5 Java 中的 super 的使用
★ superkeyword:在对象的内部使用。能够代表父类对象
訪问父类的属性 super.age
訪问父类的方法 super.eat()
★ 子类的构造的过程中必须调用其父类的构造方法,该过程隐式地使用了
super keyword
假设子类的构造方法中没有显示调用父类的构造方法,则系统默认调用父类无參的构造方法。
假设显式的调用构造方法。必须在子类的构造方法的第一行。
图:演示样例 —— 显式地调用父类的构造方法
假设子类构造方法中既没有显示调用父类的构造方法,而父类又没有无參的构造方法。则编译出错
图:父类Animal(未声明无參的构造函数)
图:子类Dog(出错)
图:报错提示
3-6 Java 中的 Object 类
Object类是全部类的父类,假设一个类没有使用extendskeyword明白标识继承另外一个类。那么这个类默认继承Object类。
Object类中的方法。适合全部子类。
★ toString()
方法
● 在Object类里面定义 toString()方法的时候,返回对象的哈希code码(对象地址字符串——唯一标识该对象)
● 能够通过重写 toString() 方法表示出对象的属性
图:三个类之间的继承关系
实例一:调用系统自带的 toString()
执行结果:
注:imocc.Dog——包名 @后面——内存地址
实例二:自己定义 toString() 方法
Step1:点击Source。选择Generate toString()
Step2: 选择想要输出的属性。点击确定
图:生成及执行效果
★ equals()方法
比較的是 对象的 引用 是否指向 同一块内存地址
普通情况下比較两个对象时。比較它们的值是否一致,所以要进行重写
实例一:调用系统自带的 .equals()
注: .equasl() 和 “==”默认比較的都是地址 —— 执行结果均为“两个对象不同样”
实例二:自己定义 toString() 方法
Step1:点击Source,选择Generate hashCode() and equals()
Step2: 选择想要输出的属性。点击确定
图:生成的代码
▲图:类对象 与 类的对象 的差别