拉不拉稀肚拉稀 发表于 2024-11-30 02:12:32

Java学习条记--继承方法的重写先容,重写方法的留意事项,方法重写的利用场

目次


一,方法的重写

二,重写方法的留意事项
三,方法重写的利用场景
四,super和this
1.继承中构造方法的特点
2.super和this的具体利用
super的具体利用
this的具体利用



一,方法的重写


1.概述:子类中有一个和父类方法名以及参数列表相同的方法
2.条件:继承
3.访问:看new的是谁,先调用谁中的,如果new的是子类,调用调用子类重写的方法,子类没有,找父类
4.检测是否为重写方法:在该方法上写
  @Override  
依旧创建三个类
public class Fu {
    public void methodFu(){
      System.out.println("我是父类中的methodFu方法");
    }

    public void method(){
      System.out.println("我是父类中的method方法");
    }
} public class Zi extends Fu{
    public void methodZi(){
      System.out.println("我是子类中的methodZi方法");
    }

    @Override
    public void method(){
      System.out.println("我是子类中的method方法");
    }
} 如果是重写,@Override不会报错,如果方法名和参数列表有一个差别就会报错
测试类
import com.atthruster.c_extends.Zi;

public class test {
    public static void main(String[] args) {
      Fu fu = new Fu();
      fu.methodFu();//自己的methodFu方法
      fu.method();//new的是父类对象,那么调用的就是父类中的method

      System.out.println("================");

      Zi zi = new Zi();
      zi.methodZi();
      zi.methodFu();//继承
      zi.method();//子类中的method方法
    }
}

二,重写方法的留意事项


1.子类重写父类方法之后,权限必须要包管大于即是父类权限(权限指的是访问权限)
  public -> protected -> 默认 -> private,例子如下,去掉method前面的public,将会报错
https://i-blog.csdnimg.cn/direct/013a1f4c5d134bde976e946a8a3b9c3e.png
但父类去掉一点事没有
https://i-blog.csdnimg.cn/direct/5ec2b804d5914e778f86e2893bf88e62.png
2.子类方法重写父类方法,方法名和参数列表要一样
3.私有方法不能被重写,构造方法不能被重写,静态方法不能被重写
静态方法
https://i-blog.csdnimg.cn/direct/b2689bd7e0794d78863d904d4874e572.png
私有方法
https://i-blog.csdnimg.cn/direct/6733d55c22744f37835a24a68b5d727d.png
构造方法
https://i-blog.csdnimg.cn/direct/0dd9b5e75c0e4039b7f588babf166760.png
4.子类重写父类方法之后,返回值类型应该是父类方法返回值类型的子类类型  
如许返回的是父类方法返回值类型的子类类型
https://i-blog.csdnimg.cn/direct/4588e6295ea945529eed204a09388660.png
相反就不可以
https://i-blog.csdnimg.cn/direct/683784d263ee4e7b81c901424a6a3721.png
三,方法重写的利用场景


1.利用场景:功能升级改造,子类需要对父类中已经实现好的功能进行重新改造
比如对旧手机的来电表现进行改造,假设老年机只能表现电话号码,如今升级可以表现来电人和归属地
创建老手机
public class Oldphone {
    public void call(){
      System.out.println("打电话");

    }
    public void message(){
      System.out.println("发短信");
    }
    public void show(){
      System.out.println("显示手机号");
    }
} 新手机
public class Newphone extends Oldphone{
    @Override
    public void show(){
      System.out.println("显示手机号");
      System.out.println("显示归属地");
      System.out.println("显示来电人");

    }
} 测试类
public class test {
    public static void main(String[] args) {
      Newphone newphone = new Newphone();
      newphone.call();//继承
      newphone.message();//继承
      newphone.show();
    }
} 效果
https://i-blog.csdnimg.cn/direct/5189f298796f40c7b7ea61d414349e07.png
四,super和this

1.继承中构造方法的特点


1.留意:new子类对象时,会先初始化父类(先走父类无参构造方法)
2.缘故原由:
  每个构造方法的第一行,默认都会有一个super(),不写jvm自动提供一个
  super()代表的是父类无参构造
例子,依旧三个类
public class Fu {
    public Fu(){
      //super();
      System.out.println("我是父类中的无参构造");
    }
} public class Zi extends Fu{
    public Zi(){
      //super();
      System.out.println("我是子类中的无参构造");
    }

    public Zi(int i){
      //super();
      System.out.println("我是子类中的有参构造");
    }
} 测试
public class test {
    public static void main(String[] args) {
      Zi zi = new Zi();


      System.out.println("=======================");
      Zi zi1 = new Zi(10);

    }
} 效果
https://i-blog.csdnimg.cn/direct/93e6ba80446b4c84b55c3cb8cbbb3527.png
2.super和this的具体利用

super的具体利用

1.概述:代表的是父类引用
2.作用:可以调用父类中的成员
3.利用:
  a.调用父类构造方法-> 在子类中的构造中写
    super() -> 调用父类无参构造
    super(实参)  -> 调用父类有参构造
      
  b.调用父类成员变量:
    super.成员变量名
        
  c.调用父类成员方法:
    super.成员方法名(实参)

//直接调用方法里的num遵循就近原则
三个类
public class Fu {
    int num = 10;
    public Fu(){
      System.out.println("我是父类中的无参构造");
    }

    public Fu(int data){
      System.out.println("我是父类中的有参构造");
    }

    public void method(){
      System.out.println("我是父类中的method方法");
    }
}
public class Zi extends Fu{
    int num = 100;
    public Zi(){
      super();//调用父类中的无参构造
      System.out.println("我是子类中的无参构造");
    }

    public Zi(int num){
      super(10);//调用父类的有参构造
      System.out.println("我是子类中的有参构造");
    }

    public void method(){
      super.method();//调用父类的method方法
      System.out.println("我是子类中的method方法");
      System.out.println(num);//子类自己的
      System.out.println(super.num);//调用父类的num
    }
} 测试类
public class Test01 {
    public static void main(String[] args) {
      Zi zi = new Zi();
      System.out.println("============");
      Zi zi1 = new Zi(10);
      System.out.println("============");
      Zi zi2 = new Zi();
      zi2.method();

    }
} 前面加了super,就可以直接调用父类引用,效果
https://i-blog.csdnimg.cn/direct/6d48dcecdee7463288af9065658722bd.png


this的具体利用

1.this概述:代表的是当前对象(哪个对象调用的this地点的方法,this就代表哪个对象)
2.作用:
  a.区分重名的成员变量和局部变量
  b.调用当前对象中的成员
3.利用:
  a.调用当前对象的构造:在构造中写
    this():调用当前对象的无参构造
    this(实参):调用当前对象的有参构造
  b.调用当前对象的成员变量:
    this.成员变量名
  c.调用当前对象的成员方法:
    this.成员方法名(实参)
4.留意:
  不管是super照旧this,只要在构造中利用,都必须在第一行,所以二者不能同时手写出来
https://i-blog.csdnimg.cn/direct/6793759c5cc04087b528682c45aac89b.png
创建一个Person类
如今调用内里的有参/无参构造,那就在无参/有参构造内里加一个this
//直接调用方法里的num遵循就近原则
public class Person {
    int num = 10;
    public Person(){
      //this(10);
      System.out.println("我是Person中的无参构造");
    }

    public Person(int data){
      //super();super和this不能同时再构造中出现
      this();
      System.out.println("我是Person中的有参构造");
    }

    public void method(){
      int num = 20;
      System.out.println(num);//20
      System.out.println(this.num);//10
      this.method01();
      System.out.println("我是Person类中的method方法");
    }

    public void method01(){
      System.out.println("我是Person类中的method01方法");
    }
}
测试类
public class Test01 {
    public static void main(String[] args) {
      Person person = new Person();
      System.out.println("========");
      Person person1 = new Person(10);
      System.out.println("========");
      Person person2 = new Person();
      person2.method();
    }
} 效果
https://i-blog.csdnimg.cn/direct/883e2e1e80b848adb2e4d59301ab8474.png














免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: Java学习条记--继承方法的重写先容,重写方法的留意事项,方法重写的利用场