1-4 继承与多态\第1节 继承

这里写自定义目录标题

  • P152day09_01_继承的概述
  • P153day09_02_继承的格式
  • P154day09_03_继承中成员变量的访问特点
    • 父子类成员变量重名?访问谁?
  • P155day09_04_区分子类方法中重名的三种变量
  • P156day09_05_继承中成员方法的访问特点_bilibili
  • P157day09_06_继承中方法的覆盖重写_概念与特点
  • P158day09_07_继承中方法的覆盖重写_注意事项
  • P159day09_08_继承中方法的覆盖重写_应用场景
  • P160day09_09_继承中构造方法的访问特点
  • P161day09_10_super关键字的三种用法
  • P162day09_11_this关键字的三种用法
  • P163day09_12_super与this关键字图解
  • P164day09_13_Java继承的三个特点

P152day09_01_继承的概述

在这里插入图片描述

P153day09_02_继承的格式

继承有什么用?
主函数中。创建子类对象,子类继承了父类,所以可以调用父类的方法。

package cn.itcast.day09.demo01;/*
在继承的关系中,“子类就是一个父类”。也就是说,子类可以被当做父类看待。
例如父类是员工,子类是讲师,那么“讲师就是一个员工”。关系:is-a。定义父类的格式:(一个普通的类定义)
public class 父类名称 {// ...
}定义子类的格式:
public class 子类名称 extends 父类名称 {// ...
}*/
public class Demo01Extends {public static void main(String[] args) {// 创建了一个子类对象Teacher teacher = new Teacher();// Teacher类当中虽然什么都没写,但是会继承来自父类的method方法。teacher.method();// 创建另一个子类助教的对象Assistant assistant = new Assistant();assistant.method();}}
package cn.itcast.day09.demo01;// 定义一个父类:员工
public class Employee {public void method() {System.out.println("方法执行!");}}
package cn.itcast.day09.demo01;// 定义了一个员工的子类:讲师
public class Teacher extends Employee {}
package cn.itcast.day09.demo01;// 定义了员工的另一个子类:助教
public class Assistant extends Employee {
}

P154day09_03_继承中成员变量的访问特点

在主函数中创建父类对象。只可以用父类的成员变量,不能用子类的。
在主函数中创建子类对象。可以用父类的成员变量,也可以用子类的。

父子类成员变量重名?访问谁?

等号左边是谁,就优先用谁,没有则向上找。

package cn.itcast.day09.demo02;/*
在父子类的继承关系当中,如果成员变量重名,则创建子类对象时,访问有两种方式:直接通过子类对象访问成员变量:等号左边是谁,就优先用谁,没有则向上找。
间接通过成员方法访问成员变量:该方法属于谁,就优先用谁,没有则向上找。*/
public class Demo01ExtendsField {public static void main(String[] args) {Fu fu = new Fu(); // 创建父类对象System.out.println(fu.numFu); // 只能使用父类的东西,没有任何子类内容System.out.println("===========");//等号左边是Zi类Zi zi = new Zi();System.out.println(zi.numFu); // 10System.out.println(zi.numZi); // 20System.out.println("===========");// 等号左边是谁,就优先用谁//等号左边是Zi类System.out.println(zi.num); // 优先子类,200
//        System.out.println(zi.abc); // 到处都没有,编译报错!System.out.println("===========");// 这个方法是子类的,优先用子类的,没有再向上找zi.methodZi(); // 200// 这个方法是在父类当中定义的,zi.methodFu(); // 100}}
package cn.itcast.day09.demo02;public class Fu {int numFu = 10;int num = 100;public void methodFu() {// 使用的是本类当中的,不会向下找子类的System.out.println(num);}}
package cn.itcast.day09.demo02;public class Zi extends Fu {int numZi = 20;int num = 200;public void methodZi() {// 因为本类当中有num,所以这里用的是本类的numSystem.out.println(num);}}

P155day09_04_区分子类方法中重名的三种变量

package cn.itcast.day09.demo03;/*
局部变量:         直接写成员变量名
本类的成员变量:    this.成员变量名
父类的成员变量:    super.成员变量名*/
public class Demo01ExtendsField {public static void main(String[] args) {Zi zi = new Zi();zi.method();}}
package cn.itcast.day09.demo03;public class Fu {int num = 10;}
package cn.itcast.day09.demo03;public class Zi extends Fu {int num = 20;public void method() {int num = 30;System.out.println(num); // 30,局部变量System.out.println(this.num); // 20,本类的成员变量System.out.println(super.num); // 10,父类的成员变量}}

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

P157day09_06_继承中方法的覆盖重写_概念与特点

new = 创建
new Zi();
创建的是Zi();所以优先用子类。

package cn.itcast.day09.demo04;/*
在父子类的继承关系当中,创建子类对象,访问成员方法的规则:创建的对象是谁,就优先用谁,如果没有则向上找。注意事项:
无论是成员方法还是成员变量,如果没有都是向上找父类,绝对不会向下找子类的。重写(Override)
概念:在继承关系当中,方法的名称一样,参数列表也一样。重写(Override):方法的名称一样,参数列表【也一样】。覆盖、覆写。
重载(Overload):方法的名称一样,参数列表【不一样】。方法的覆盖重写特点:创建的是子类对象,则优先用子类方法。*/
public class Demo01ExtendsMethod {public static void main(String[] args) {Zi zi = new Zi();zi.methodFu();zi.methodZi();// 创建的是new了子类对象,所以优先用子类方法zi.method();}}
package cn.itcast.day09.demo04;public class Fu {public void methodFu() {System.out.println("父类方法执行!");}public void method() {System.out.println("父类重名方法执行!");}}
package cn.itcast.day09.demo04;public class Zi extends Fu {public void methodZi() {System.out.println("子类方法执行!");}public void method() {System.out.println("子类重名方法执行!");}}

P158day09_07_继承中方法的覆盖重写_注意事项

@Override,可写可不写,推荐写。因为可以检测你写的对不对。
虽然有注意事项,但是绝多数情况下,都是一样。

package cn.itcast.day09.demo05;/*
方法覆盖重写的注意事项:1. 必须保证父子类之间方法的名称相同,参数列表也相同。
@Override:写在方法前面,用来检测是不是有效的正确覆盖重写。
这个注解就算不写,只要满足要求,也是正确的方法覆盖重写。2. 子类方法的返回值必须【小于等于】父类方法的返回值范围。
小扩展提示:java.lang.Object类是所有类的公共最高父类(祖宗类),java.lang.String就是Object的子类。3. 子类方法的权限必须【大于等于】父类方法的权限修饰符。
方法前面的修饰符就是【权限】
小扩展提示:public > protected > (default) > private
备注:(default)不是关键字default,而是什么都不写,留空。*/
public class Demo01Override {}
package cn.itcast.day09.demo05;public class Fu {public String method() {return null;//为什么可以这样写?//所有的引用类型都可以用null来返回。}}
package cn.itcast.day09.demo05;public class Zi extends Fu {@Overridepublic String method() {return null;}}

P159day09_08_继承中方法的覆盖重写_应用场景

小米手机旧版,推出新款的时候,把以前的给覆盖重写了。
尽量不要修改【旧的类】,
一般我们这样处理。添加【旧的类】,用super.去调用。然后再自己添加。

package cn.itcast.day09.demo06;public class Demo01Phone {public static void main(String[] args) {Phone phone = new Phone();phone.call();phone.send();phone.show();System.out.println("==========");NewPhone newPhone = new NewPhone();newPhone.call();newPhone.send();newPhone.show();}}
package cn.itcast.day09.demo06;// 本来的老款手机
public class Phone {public void call() {System.out.println("打电话");}public void send() {System.out.println("发短信");}public void show() {System.out.println("显示号码");}}
在这里插入代码片
package cn.itcast.day09.demo06;// 定义一个新手机,使用老手机作为父类
public class NewPhone extends Phone {@Overridepublic void show() {super.show(); // 把父类的show方法拿过来重复利用// 自己子类再来添加更多内容System.out.println("显示姓名");System.out.println("显示头像");}
}

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

重载:方法名一样,参数列表不一样。
父类有两个构造方法。
子类要调用父类的构造方法,只能够调用一个。
只能super一个。

package cn.itcast.day09.demo07;/*
继承关系中,父子类构造方法的访问特点:1. 子类构造方法当中有一个默认隐含的“super()”调用,所以一定是先调用的父类构造,后执行的子类构造。
2. 子类构造可以通过super关键字来调用父类重载构造。
3. super的父类构造调用,必须是子类构造方法的第一个语句。不能一个子类构造调用多次super构造。
总结:
子类必须调用父类构造方法,不写则赠送super();写了则用写的指定的super调用,super只能有一个,还必须是第一个。*/
public class Demo01Constructor {public static void main(String[] args) {Zi zi = new Zi();}}
package cn.itcast.day09.demo07;/*
继承关系中,父子类构造方法的访问特点:1. 子类构造方法当中有一个默认隐含的“super()”调用,所以一定是先调用的父类构造,后执行的子类构造。
2. 子类构造可以通过super关键字来调用父类重载构造。
3. super的父类构造调用,必须是子类构造方法的第一个语句。不能一个子类构造调用多次super构造。
总结:
子类必须调用父类构造方法,不写则赠送super();写了则用写的指定的super调用,super只能有一个,还必须是第一个。*/
public class Demo01Constructor {public static void main(String[] args) {Zi zi = new Zi();}}
package cn.itcast.day09.demo07;public class Zi extends Fu {public Zi() {super(); // 在调用父类无参构造方法
//        super(20); // 在调用父类重载的构造方法System.out.println("子类构造方法!");}public void method() {
//        super(); // 错误写法!只有子类构造方法,才能调用父类构造方法。}}

P161day09_10_super关键字的三种用法

package cn.itcast.day09.demo08;/*
super关键字的用法有三种:
1. 在子类的成员方法中,访问父类的成员变量。
2. 在子类的成员方法中,访问父类的成员方法。
3. 在子类的构造方法中,访问父类的构造方法。*/
public class Zi extends Fu {int num = 20;
//3. 在子类的构造方法中,访问父类的构造方法。public Zi() {super();}
//1. 在子类的成员方法中,访问父类的成员变量。public void methodZi() {System.out.println(super.num); // 父类中的num}
//2. 在子类的成员方法中,访问父类的成员方法。public void method() {super.method(); // 访问父类中的methodSystem.out.println("子类方法");}}
package cn.itcast.day09.demo08;public class Fu {int num = 10;public void method() {System.out.println("父类方法");}}

P162day09_11_this关键字的三种用法

package cn.itcast.day09.demo09;/*
super关键字用来访问父类内容,而this关键字用来访问本类内容。用法也有三种:1. 在本类的成员方法中,访问本类的成员变量。
2. 在本类的成员方法中,访问本类的另一个成员方法。
3. 在本类的构造方法中,访问本类的另一个构造方法。
在第三种用法当中要注意:
A. this(...)调用也必须是构造方法的第一个语句,唯一一个。
B. super和this两种构造调用,不能同时使用。因为他们必须是第一行,不可能有两个第一行。*/
public class Zi extends Fu {int num = 20;public Zi() {
//        super(); // 这一行不再赠送this(123); // 本类的无参构造,调用本类的有参构造
//        this(1, 2); // 错误写法!}public Zi(int n) {this(1, 2);}public Zi(int n, int m) {}public void showNum() {int num = 10;System.out.println(num); // 局部变量System.out.println(this.num); // 本类中的成员变量System.out.println(super.num); // 父类中的成员变量}public void methodA() {System.out.println("AAA");}public void methodB() {this.methodA();System.out.println("BBB");}}
package cn.itcast.day09.demo09;public class Fu {int num = 30;}

P163day09_12_super与this关键字图解

super_class是编译完后有的特殊标记。
new出来的东西在堆中。

子类中有父类的完整内容。
意思是,先有父类的构造。后有子类的添加新的东西。

package cn.itcast.day09.demo10;public class Demo {public static void main(String[] args) {Zi zi = new Zi();zi.show();zi.method();}}
package cn.itcast.day09.demo10;public class Fu {int num = 10;public void method() {System.out.println("父类方法");}}
package cn.itcast.day09.demo10;public class Zi extends Fu {int num = 20;@Overridepublic void method() {super.method(); // 调用了父类方法System.out.println("子类方法");}public void show() {int num = 30;System.out.println(num); // 30System.out.println(this.num); // 20System.out.println(super.num); // 10}}

在这里插入图片描述

P164day09_13_Java继承的三个特点

在这里插入图片描述


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部