• Tidak ada hasil yang ditemukan

幻灯片 1

N/A
N/A
Protected

Academic year: 2023

Membagikan "幻灯片 1"

Copied!
29
0
0

Teks penuh

(1)

继承

(2)

1. 继承

1.1 继承概述

public class Student { private String name;

private int age;

public void study(){

System.out.println(" 努力学习 ");

}

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 class Teacher { private String name;

private int age;

public void teach(){

System.out.println(" 教书育人 ");

}

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;

} }

相同的属性

相同的方法

相同

特征

(3)

1. 继承

1.1 继承概述

public class Student { private String name;

private int age;

public void study(){

System.out.println(" 努力学习 ");

}

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 class Teacher { private String name;

private int age;

public void teach(){

System.out.println(" 教书育人 ");

}

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;

} }

相同的属性

相同的方法

相同

特征

(4)

public class Student {

public void study(){

System.out.println(" 努力学习 ");

}

}

public class Teacher {

public void teach(){

System.out.println(" 教书育人 ");

}

}

1. 继承

1.1 继承概述

public class Student { public void study(){

System.out.println(" 努力学习 ");

} }

public class Teacher { public void teach(){

System.out.println(" 教书育人 ");

} }

相同 特征

public class ?????? { 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;

}

??关系

}

??关系

(5)

1. 继承

1.1 继承概述

继承是面向对象三大特征之一。可以使得子类具有父类的属性和方法,还可以在子类中重新定义,追加属性和方法

(6)

1. 继承

1.1 继承概述

继承的格式

格式:public class 子类名 extends 父类名 { }

范例:public class Zi extends Fu { }

Fu:是父类,也被称为基类、超类

Zi:是子类,也被称为派生类

继承中子类的特点:

子类可以有父类的内容

子类还可以有自己特有的内容

(7)

1. 继承

1.2 继承的好处和弊端

继承好处

提高了代码的复用性( 多个类相同的成员可以放到同一个类中)

提高了代码的维护性( 如果方法的代码需要修改,修改一处即可)

继承弊端

继承让类与类之间产生了关系,类的耦合性增强了,当父类发生变化时子类实现也不得不跟着变化,削弱了子类的独立性

什么时候使用继承?

继承体现的关系:is a

假设法:我有两个类 A 和B ,如果他们满足 A 是B 的一种,或者 B是A 的一种,就说明他们存在继承关系,这个时候就可以考虑使用 继承来体现,否则就不能滥用继承

举例:苹果和水果,猫和动物,猫和狗

(8)

1. 继承

1.3 继承中变量的访问特点

在子类方法中访问一个变量

子类局部范围找

子类成员范围找

父类成员范围找

如果都没有就报错 ( 不考虑父亲的父亲… )

(9)

1. 继承

1.4 super

super 关键字的用法和 this 关键字的用法相似

this:代表本类对象的引用

super:代表父类存储空间的标识 ( 可以理解为父类对象引用)

关键字 访问成员变量 访问构造方法 访问成员方法

this

this.成员变量

访问本类成员变量

this(…) 访问本类构造方法

this.成员方法(…) 访问本类成员方法

super

super.成员变量

访问父类成员变量

super(…) 访问父类构造方法

super.成员方法(…) 访问父类成员方法

(10)

1. 继承

1.5 继承中构造方法的访问特点

子类中所有的构造方法默认都会访问父类中无参的构造方法 为什么呢?

因为子类会继承父类中的数据,可能还会使用父类的数据。所以,子类初始化之前,一定要先完成父类数据的初始化

每一个子类构造方法的第一条语句默认都是:super()

如果父类中没有无参构造方法,只有带参构造方法,该怎么办呢?

通过使用super关键字去显示的调用父类的带参构造方法

在父类中自己提供一个无参构造方法 推荐:自己给出无参构造方法

(11)

1. 继承

1.6 继承中成员方法的访问特点

通过子类对象访问一个方法

子类成员范围找

父类成员范围找

如果都没有就报错 ( 不考虑父亲的父亲… )

(12)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

方法:main

方法:main

(13)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

方法:main 方法:main Zi z

20

age

new 001Zi()

public class Zi extends Fu { public int age = 20;

public Zi() {

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

构造方法:Zi

构造方法:Zi

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

public class Fu {

public int age = 40;

public Fu() {

System.out.println("Fu类无参构造方法被调用");

}

public void method() {

System.out.println("Fumethod方法被调用");

} }

方法:main

Zi z 001

(14)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

public class Zi extends Fu { public int age = 20;

public Zi() {

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

public class Fu {

public int age = 40;

public Fu() {

System.out.println("Fu类无参构造方法被调用");

}

public void method() {

System.out.println("Fumethod方法被调用");

} }

方法:main

Zi z 001

构造方法:Zi

构造方法:Fu

构造方法:Fu

40

age

super

输出:

Fu 类无参构造方法被调

(15)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:main

Zi z 001

构造方法:Zi

40

age

super

输出:

Fu 类无参构造方法被调

输出:

Zi 类无参构造方法被调

(16)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:show

方法:show 方法:show 调用者:z (001) 方法:show 调用者:z (001) this: z (001) 方法:show 调用者:z (001) this: z (001) int age 30

(17)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:show 调用者:z (001) this: z (001) int age 30

输出:

30

(18)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:show 调用者:z (001) this: z (001) int age 30

输出:

30

输出:

20

(19)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:show 调用者:z (001) this: z (001) int age 30

输出:

30

输出:

20

输出:

40

(20)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

方法:show 调用者:z (001) this: z (001) int age 30

输出:

30

输出:

20

输出:

40

(21)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

输出:

30

输出:

20

输出:

40

public class Zi extends Fu { public int age = 20;

public Zi() { super();

System.out.println("Zi类无参构造方法被调用");

}

public void show() { int age = 30;

System.out.println(age);

System.out.println(this.age);

System.out.println(super.age);

} }

public class Fu {

public int age = 40;

public Fu() {

System.out.println("Fu类无参构造方法被调用");

}

public void method() {

System.out.println("Fumethod方法被调用");

} }

输出:

Fumethod 方法被调

(22)

1. 继承

1.7 super 内存图

public class Demo {

public static void main(String[] args) { Zi z = new Zi();

z.show();

z.method();

} }

栈内存 堆内存

20

age

new 001Zi()

方法:main

Zi z 001

40

age

super

输出:

Fu 类无参构造方法被调 用

输出:

Zi 类无参构造方法被调 用

输出:

30

输出:

20

输出:

40

输出:

Fumethod 方法被调

(23)

1. 继承

1.8 方法重写

方法重写概述

子类中出现了和父类中一模一样的方法声明

方法重写的应用

当子类需要父类的功能,而功能主体子类有自己特有内容时,可以重写父类中的方法,这样,即沿袭了父类的功能,

又定义了子类特有的内容

练习:手机类和新手机类

@Override

是一个注解 (注解后面会学习到)

可以帮助我们检查重写方法的方法声明的正确性

(24)

1. 继承

1.9 方法重写注意事项

 私有方法不能被重写( 父类私有成员子类是不能继承的)

 子类方法访问权限不能更低(public > 默认 > 私有)

(25)

public class Son extends Father { }

1. 继承

1.10 Java 中继承的注意事项

 Java中类只支持单继承,不支持多继承

 Java中类支持多层继承

public class Granddad { public void drink() {

System.out.println("爷爷爱喝酒");

} }

public class Father extends Granddad { public void smoke() {

System.out.println("爸爸爱抽烟");

} } public class Mother {

public void dance() {

System.out.println("妈妈爱跳舞");

} }

public class Son extends Father, Mother { }

(26)

1. 继承

案例:老师和学生

需求:定义老师类和学生类,然后写代码测试;最后找到老师类和学生类当中的共性内容,抽取出一个父类,

用继承的方式改写代码,并进行测试 思路:

①定义老师类 (姓名,年龄,教书())

②定义学生类 (姓名,年龄,学习())

③定义测试类,写代码测试

④共性抽取父类,定义人类 (姓名,年龄)

⑤定义老师类,继承人类,并给出自己特有方法:教书()

⑥定义学生类,继承人类,并给出自己特有方法:学习()

⑦定义测试类,写代码测试

(27)

1. 继承

案例:猫和狗

需求:请采用继承的思想实现猫和狗的案例,并在测试类中进行测试 分析:

①猫:

成员变量:姓名,年龄 构造方法:无参,带参

成员方法:get/set方法,抓老鼠()

②狗:

成员变量:姓名,年龄 构造方法:无参,带参

成员方法:get/set方法,看门()

③共性:

成员变量:姓名,年龄;构造方法:无参,带参;成员方法:get/set方法

(28)

1. 继承

案例:猫和狗

需求:请采用继承的思想实现猫和狗的案例,并在测试类中进行测试 思路:

①定义动物类(Animal) 成员变量:姓名,年龄 构造方法:无参,带参 成员方法:get/set方法

②定义猫类(Cat),继承动物类 构造方法:无参,带参 成员方法:抓老鼠()

③定义狗类(Dog),继承动物类 构造方法:无参,带参 成员方法:看门()

④定义测试类(AnimalDemo),写代码测试

(29)

Referensi

Dokumen terkait

或门电路 的逻辑关系 符号 逻辑示意图... 非门电路的逻辑关系 逻辑示意图

高中物理选修 3-4 课件 二、对质能方程的理解 质能方程表达了物体的质量和它所具有的能量的 关系:一定的质量总是和一定的能量相对应. 具体从以下几个方面理解: 1.. 静止物体的能量为 E0= m0c2, 这种能量叫做物

错因:误认为匀速圆周运动是速度不变的运动,即匀速运 动. 正解:匀速圆周运动是曲线运动,线速度方向时刻在改变, 故加速度不为零;匀速圆周运动的线速度大小不变,即线速率 不变. 答案:

高中物理选修 3-3 课件 • 解析: 第二种表述的意思是:热机吸收热量,对外 做功,同时把热量传给低温物体.其表述示意图如图 所示.其实质是:一切与热现象有关的宏观过程都具 有方向性. • 答案: 其表述示意图如图所示 一切与热现象有关

平面的方程 (熟记平面的几种特殊位置的方程) 两平面的夹角... (注意两直线的位置关系) (注意直线与平面的位置关系)

1 .方向: 总是沿着圆周运动的半径指向圆心,不论加速度 an 的大小 是否变化, an 的方向是时刻改变的,所以圆周运动一定是变加 速运动. 2 .大小:... 加速度,不过任何圆周运动的向心加速度公式都是 an =—=

知识点 2 开普勒第二定律 经过数十亿年的演化,地球上现存的有记载的生物中,植物 大约有 50 多万种,动物大约有 150 多万种,而尚未被发现的现存 生物的种数可能是这总数的 3 倍之多,但现存生物的种数却还不 及地球上曾存在的生物种数的五十分之一. 地球上孕育出如此之多的形形色色的生物,可谓和季节变化

知识点 牛顿定律的经典性和局限性 欧洲核子研究中心曾在 2011 年宣布发现了速度大于光速的粒 子,这在科学界引起了不小的轰动,但次年 2 月,研究人员在对 该实验系统重新进行测试后,揪出了两个疑似故障,则这一结果 很有可能是在实验存在异常因素的情况下所得到的. 根据爱因斯坦提出的狭义相对论,任何物体的速度都不可能