【Java】面向对象之继承篇

简介: 一、前言二、继承什么是继承呢?继承的好处与弊端继承的使用场景?继承的格式:继承的特点:重写的概念:super关键字super和this的比较

public class fu{
   void eat(){
   System.out.println("fu中eat方法");
  }
}

一、前言


前面我也们讲述了相关封装的,现在我们先认识的继承的概念和使用。


二、继承


什么是继承呢?


继承在显示生活中也不少见,比如继承财产之类的,在我们java学习中也有类似的使用,


继承者称作子类也叫派生类,被继承者称作父类、基类或超类,objec类是所有类的父类


(后期介绍)

继承的好处与弊端


好处:就是提高了代码的维护性(多个代码需要修改,只需要修该一处即可)。

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

弊端:继承的缺点就是使代码之间的耦合度高,修改父类子类也会跟着变化


继承的使用场景?


两个有从属关系的,比如猫和动物,学生和人等。


继承的关键词是extends。


继承的格式:


public class  子类名 extends  父类名{}


举例:


public class Cat extends Animal{}//猫继承动物类

继承的特点:


子类可以拥有父类的非私有方法和成员变量,也可以重写父类的非私有(private修饰的)方法。所有子类的方法都默认访问父类的无参构造


重写的概念:


重写是子类重述父类中的非私有方法,重写的一般特点是方法名相同,格式相同,返回类型相同、方法体不同


如:


fu类中:


public class fu{
  public void  play(){
   System.out.println("fu喜欢打羽毛球");
  }
}


zi类中:


public class  zi extends fu{
    public void play(){//对父类的方法重写
   System.out.println("zi喜欢打篮球");
    }
} 


还可以这么写,访问权限需要zi类大于等于fu类


fu类中修饰是默认:


public class fu{
   void eat(){
   System.out.println("fu中eat方法");
  }
}


zi类中:

public class Zi extends Fu {
    @Override//检测方法重写的正确性
   public void eat() {
        System.out.println("zi中的eat方法");
    }
}


zi类中重写:


public class Zi extends Fu {
   // @Override写不写不会影响,这个只是起到辅助作用
   void eat() {
        System.out.println("zi中的eat方法");
    }
}


zi还可以:


public class Zi extends Fu {
    @Override
  protected  void eat() {
        System.out.println("zi中的eat方法");
    }
}


修饰访问关系public>protected>默认(不写)>private


当父类的权限修饰符是默认(也就是不写修饰符),子类重写的修饰方法可以是默认和


默认之前的以此类推。注:当父类的权限修饰符是private时,那子类可不是private


之前的。当父类被private修饰时,子类不能重写此类方法


super关键字


当子类中的成员变量和父类中成员变量同名时,我们想使用父类中的成员变量时,


或者我们重写了父类中方法时,我们还想调用父类中的方法时。此时我们就要使用super


关键字来调用父类中的成员。


super和this的比较


super和this的使用原理差不多,this是解决了局部变量和成员变量同名时,局部变量对


成员的覆盖super是解决子类对父类的覆盖


当局部变量,成员变量,父类中的变量同名时,访问的是局部变量。可以用this和super改变。


public class fu{
  public int age=40; 
public fu(){}//无参构造
public fu(int age){//带参构造
  this.age=age;}
  public void eat(){
   System.out.println("fu中eat方法");
  }
}
public class Zi extends Fu {
  public  int age=18;
public Zi(){}
public Zi(int age){
  this.age=age;}
    public void eat() {
      super.eat();
        System.out.println("zi中的eat方法");
    }
public void show(){
  int age=1;
  System.out.println(age);//1局部变量的值
  System.out.println(this.age);//18子类成员中的值
  System.out.println(super.age);//40父类中的值
}
public class Demo{
  public static void main(String[] args){
    zi z=new zi();
     z.eat();
     z.show();
  }
}



目录
相关文章
|
23天前
|
Java 关系型数据库 数据库
面向对象设计原则在Java中的实现与案例分析
【10月更文挑战第25天】本文通过Java语言的具体实现和案例分析,详细介绍了面向对象设计的五大核心原则:单一职责原则、开闭原则、里氏替换原则、接口隔离原则和依赖倒置原则。这些原则帮助开发者构建更加灵活、可维护和可扩展的系统,不仅适用于Java,也适用于其他面向对象编程语言。
14 2
|
28天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
19 3
|
28天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
37 2
|
28天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
30 2
|
28天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
34 1
|
2月前
|
Java 编译器
封装,继承,多态【Java面向对象知识回顾①】
本文回顾了Java面向对象编程的三大特性:封装、继承和多态。封装通过将数据和方法结合在类中并隐藏实现细节来保护对象状态,继承允许新类扩展现有类的功能,而多态则允许对象在不同情况下表现出不同的行为,这些特性共同提高了代码的复用性、扩展性和灵活性。
封装,继承,多态【Java面向对象知识回顾①】
|
1月前
|
Java 测试技术 编译器
Java零基础-继承详解!
【10月更文挑战第4天】Java零基础教学篇,手把手实践教学!
39 2
|
1月前
|
Java 编译器
在Java中,关于final、static关键字与方法的重写和继承【易错点】
在Java中,关于final、static关键字与方法的重写和继承【易错点】
23 5
|
1月前
|
Java
java继承和多态详解
java继承和多态详解
43 5
|
1月前
|
Java 编译器
【一步一步了解Java系列】:子类继承以及代码块的初始化
【一步一步了解Java系列】:子类继承以及代码块的初始化
26 3