1.继承的定义以及基本使用
定义:子类能够继承父类的共有属性和方法;
特点:Java中只支持单继承,私有方法不能被继承;
实现继承的类被称为子类(也叫派生类),被继承的类被称为父类(也叫基类).
Java的继承通过extends关键字实现.
先写一个父类Animals类:
定义两个私有属性 name和age 然后给出共有的set和get接口 以及一个共有的say()方法;
package m10d28;
public class Animals {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void speak(){
System.out.println("我是一只动物,我叫"+this.getName()+",我的年龄是"+this.getAge());
}
}
再写一个子类Dog类,通过extends关键字 继承Animal类:
实际上把父类Animal的共有方法get set以及say()方法都继承了;
package m10d28;
public class Dog extends Animals{
public static void main(String[] args) {
Dog dog=new Dog();
dog.setName("dog");
dog.setAge(2);
dog.speak();
}
}
输出结果:
我是一只动物,我叫dog,我的年龄是2
2,方法重写
定义:所谓方法的重写 我们可以在子类中根据实际要求把父类的方法重写;
package m10d28;
public class Cat extends Animals{
public void speak(){
System.out.println("我是一只猫,我重写了父类的方法,我叫"+this.getName()+",我的年龄是"+this.getAge());
}
public static void main(String[] args) {
Cat dog=new Cat();
dog.setName("Cat");
dog.setAge(2);
dog.speak();
}
}
注意:重写的方法里面的this.getName()和this.getAge()不能更改为this.name和this.age,
因为Cat对象里继承不到父类的私有字段;
输出结果:
我是一只猫,我重写了父类的方法,我叫Cat,我的年龄是2
3,对象实例过程以及super关键字
对象实例化 先实例化调用父类构造方法,再调用子类实例化构造方法;
super关键主要是调用父类方法或者属性;
我们先来看看父类和子类的构造方法是如何调用的,顺序是怎样的:
我们先在父类Animals中添加父类无参构造方法和父类有参构造方法:
//添加无参构造方法
public Animals(){
System.out.println("父类无参构造方法!");
}
//添加有参构造方法
public Animals(String name, int age) {
System.out.println("父类有参构造方法!");
this.name = name;
this.age = age;
}
在子类Cat中添加子类无参构造方法:
public Cat(){
System.out.println("子类无参构造方法!");
}
输出结果为:
父类无参构造方法!
子类无参构造方法!
我是一只猫,我重写了父类的方法,我叫Cat,我的年龄是2
程序是先调用父类的无参构造方法,再调用子类的无参构造方法!
super关键字的引用:
现在再来看看,如果在子类中用构造方法进行实例化的时候,在子类有参构造方法中
运用this.name或者this.getName()来调用父类私有属性会怎样?
由上图可知,如果直接在子类有参构造方法中运用this.name或者this.getName()等都是会报错的!
因为name和age在父类中都是private类型的,子类是没有访问权限的!
那么,如何在子类有参构造方法中调用父类的属性和方法呢?
这时,super()关键字就可以派上用场了;前面说过:
super关键主要是调用父类方法或者属性;
在Cat子类中添加有参构造方法,并且实例化:
package m10d28;
public class Cat extends Animals{
public void speak(){
System.out.println("我是一只猫,我重写了父类的方法,我叫"+this.getName()+",我的年龄是"+this.getAge());
}
public Cat(){
System.out.println("子类无参构造方法!");
}
public Cat(String name,int age){
super(name,age);
System.out.println("子类有参构造方法!");
}
public static void main(String[] args) {
Cat dog=new Cat("Cat",3);
dog.speak();
}
}
输出结果:
父类有参构造方法!
子类有参构造方法!
我是一只猫,我重写了父类的方法,我叫Cat,我的年龄是3
这是由子类有参构造方法进行实例化的,而且用super关键字就可以调用父类私有属性和方法!
当然,可能有人会想,我直接调用父类有参构造方法不就行了;
但是偶尔子类也有自己独特的属性,这时也需要父类的属性一起:
package m10d28;
public class Cat extends Animals{
public Cat(){
System.out.println("子类无参构造方法!");
}
//给Cat添加一个独特的属性sex
private String sex;
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Cat(String name,int age,String sex){
super(name,age);
this.sex=sex;
System.out.println("子类有参构造方法!");
}
public void speak(){
System.out.println("我是一只猫,我重写了父类的方法,我叫"+this.getName()+
",我的年龄是"+this.getAge()+",我的性别是"+this.sex);
}
public static void main(String[] args) {
Cat dog=new Cat("Cat",5,"雌性");
dog.speak();
}
}
输出结果:
父类有参构造方法!
子类有参构造方法!
我是一只猫,我重写了父类的方法,我叫Cat,我的年龄是5,我的性别是雌性