Java笔记(5)——类的继承、访问控制、super关键字

2023-05-16

  在类中,不写构造方法,相当于执行了默认的无参构造方法;写了有参构造方法,则只执行有参构造方法,默认的无参构造方法则会被屏蔽掉;若想拥有有参和无参构造方法,则同时显示地写出这两种构造方法。

1. 类的继承

使用extends来继承父类。

  1. 不管子类的构造器中是否有参,甚至是是否含有构造器,均会执行父类的无参构造器,即父类的无参构造器隐式地包含在子类的构造器中。super()存在。
  2. 若子类中具有有参构造器,如果是自己独有的构造器,则会继承父类的无参构造器(如果父类中不存在无参构造器,此时会报错);如果是对父类构造器的重载,则在子类的构造器中必须含有super(XXX),执行父类中相应的被重载的构造器,再执行子类中重载父类构造器后的子类构造器;若子类中没有写出super(XXX)字样,则子类的构造器默认执行父类的无参构造器,相应的子类构造器中的参数也不会被传入到对象中。

相应的分类别的多种情况,可见博文的最下面的长图。

example1

在这里插入图片描述

public class ManKind {
    public String name;
    public int sex;
    public int salary;

    public void setSalary(int salary){
        this.salary = salary;
    }

    public void setSex(int sex){
        this.sex = sex;
    }

    public void setName(String name){
        this.name = name;
    }

    public void manOrwoman(){
        if(this.sex == 1)
            System.out.println("man!");
        else if(this.sex == 0)
            System.out.println("woman!");
        else
            System.out.println("Error!");
    }

    public void employeed(){
        if(this.salary > 0)
            System.out.println("Job!");
        else
            System.out.println("no Job!");
    }
}


public class Kid1 extends ManKind{
    private int yearsOld;

    public Kid1(String name){
        this.name = name;
    }

    public void setYearsOld(int yearsOld){
        this.yearsOld = yearsOld;
    }

    public void printAge(){
        System.out.println(this.name + "的年龄是:" + this.yearsOld);
    }

    public void printInfo(){
        System.out.println(this.name + "的性别是:" + this.sex + ",年龄是:" + this.yearsOld);
    }

}


public class TestKids1 {
    public static void main(String[] args) {
        Kid1 k1 = new Kid1("Tom");
        k1.setSalary(2000);
        k1.setSex(1);

        k1.setYearsOld(20);
        k1.manOrwoman();
        k1.printAge();
        k1.printInfo();
    }
}


/*
man!
Tom的年龄是:20
Tom的性别是:1,年龄是:20
*/

example2

在这里插入图片描述

public class Circle {
    public double radius;

    public Circle(){
          this.radius = 1;
    }

    public void setRadius(double radius){
        this.radius = radius;
    }

    public double getRadius(){
        return this.radius;
    }

    public double findArea(){
        //System.out.println("圆的面积是:" + Math.PI * this.radius * this.radius);
        return Math.PI * this.radius * this.radius;
    }
}


public class Cylinder extends Circle{
    private double length;

    public Cylinder(){
        this.length = 1;
    }

    public void setLength(double length){
        this.length = length;
    }

    public double getLength(){
        return this.length;
    }

    public void findVolume(){
        System.out.println("底面半径为"  + this.radius + ",高为" + this.length +
                "的圆柱面积是:" + length * findArea());
    }


}


public class TestCylinder {
    public static void main(String[] args) {
        Cylinder cy1 = new Cylinder();
        cy1.setRadius(12.3);
        cy1.setLength(5.4);
        cy1.findVolume();
    }
}
/*
底面半径为12.3,高为5.4的圆柱面积是:2566.5743838326393
*/

2. 访问控制

可以对Java类中定义的属性和方法进行访问控制,规定不同的保护级别:public,protected,defalut,private

3. 方法的重写

子类中可以根据需要对父类中继承的方法进行改造。
子类对父类的扩展。

// 在父类中的方法
public void employeed(){
    if(this.salary > 0)
        System.out.println("Job!");
    else
        System.out.println("no Job!");
}

// 在子类中的方法,对父类中的方法进行重写。
public void employeed(){
    System.out.println("学生只能学习没有工作!");
}

4. 关键字super

  1. 在子类中已经重写了父类的方法,在子类中引用父类对象的成员。使用super.来替代。

// 父类方法
public String getInfo(){
    return "name:" + name + ",sex:"
            + sex + ",salary:" + salary;
}

// 子类的方法
public String getInfo(){
    return super.getInfo() + ",yearsOld:" + yearsOld;
}

System.out.println(k1.getInfo());
/*
name:Tom,sex:1,salary:2000,yearsOld:20
*/
  1. 在子类的构造器中 调用父类的构造器。
  • 2.1 可以在子类中使用super()的方法或者是参数列表的方式来调用父类的构造器。

  • 2.2 默认情况下,子类的构造器调用父类的无参数的构造器。

  • 2.3 如果父类定义了带参数的构造器,则系统不再为父类提供无参数的构造器,而子类的构造器中必须调用父类的一个构造器。

// 父类中的方法
public double findArea(){
    //System.out.println("圆的面积是:" + Math.PI * this.radius * this.radius);
    return Math.PI * this.radius * this.radius;
}

// 子类调用父类的方法
public double findArea(){
    return 2 * super.findArea() + 2 * Math.PI * this.radius * this.length;
}

public void findVolume(){
    System.out.println("底面半径为"  + this.radius + ",高为" + this.length +
            "的圆柱面积是:" + length * findArea());
}

/*
圆柱的表面积是:1367.912273226068
*/


该图片转载自:https://www.cnblogs.com/12three/p/11914709.html

在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Java笔记(5)——类的继承、访问控制、super关键字 的相关文章

随机推荐

  • 三种修改windows系统MAC地址方法

    方法一 xff1a 使用windows控制面板修改 第一步 按win键 gt 输入 控制面板 并打开 第二步 打开 网络和共享中心 第三步 打开 更改适配器设置 第四步 右击 WLAN2 后点击属性 第五步 修改网络地址属性 点击配置 xf
  • 【操作系统实验】Linux环境下用进程实现生产者消费者问题——C语言完整代码+详细实验报告

    注意 代码在文末 xff0c 以下为详细实验报告 实验目的 以生产者和消费者问题为例 xff0c 学习并熟悉Linux下进程通信 同步机制的具体实现方法 xff0c 主要是了解并掌握信号量机制和共享内存的使用方法 xff0c 进一步熟悉Li
  • mariadb的源码安装

    xff08 1 xff09 登上mariadb的官方网站 2 选择下载mariadb server 3 下载10 2版本 4 找到源码安装方式 xff08 5 xff09 下载传输到主机上 6 准备编译环境 yum span class t
  • HTTP协议以及Apache的httpd配置

    HTTP协议 前言HTTP简介HTTP诞生HTTP版本历史HTTP 0 9HTTP 1 0HTTP 1 1HTTP 2 0 web资源HTTP工作流程HTTP报文报文语法格式method xff08 方法 xff09 status xff0
  • 狂神说Redis笔记,Redis【入门】就这一篇就够了!

    Redis学习笔记 视频链接 xff1a 狂神说Redis链接 1 Nosql概述 1 1 为什么要使用Nosql 1 单片机Mysql时代 90年代 xff0c 一个网站的访问量太大 xff0c 单个数据库完全够用 随着用户的增多 xff
  • manjaro一些常用软件,指令(持续更新中)

    manjaro使用很久了 xff0c 由于对linux的陌生和迷惑 xff0c 重装了很多很多很多次 xff0c 最近的系统大概是使用最久的一次 xff0c 也解决了很多以前的问题在此记录下 系统如下 xff1a 软件安装 换源 烂大街的教
  • 在开发板上安装gdb

    网上对于在开发板上安装gdb的教程大多都是将开发板的文件系统放在虚拟机主机上 xff0c 从而通过nfs挂载上去的 xff0c 主要是针对性能较差开发板 xff0c 本教程讲解的是如何在开发板上直接安装gdb 为什么不能直接将pc上交叉编译
  • Idea Intellij 远程开发调试

    一 背景 在构建MiniOB开发环境时需要Linux环境 xff0c 另外结合分布式系统 xff0c 利用较好的通信 xff0c 萌发了远程开发的想法 xff1b 实际上远程部署 开发在很久之前有过想法 xff08 大约刚开始学Spring
  • Java笔记(4)——方法重载和this关键字

    1 方法的重载 不能通过参数名去区分两个方法 不能通过返回值类型来区分两个方法 可以通过参数列表 xff1a 参数个数 xff0c 参数类型来区分 span class token keyword public span span clas
  • 基于 java+springboot 工资管理系统设计和实现

    博主介绍 xff1a 5年java开发经验 xff0c 专注Java开发 定制 远程 指导等 csdn特邀作者 专注于Java技术领域 作者主页 超级帅帅吴 Java项目精品实战案例 500套 欢迎点赞 收藏 留言 文末获取源码联系方式 目
  • ubuntu 安装gcc 或g++ 时提示未发现软件包 gcc或g++

    问题 xff1a 安装gcc 或g 43 43 时提示未发现软件包 xff1f 1 这时 xff0c 只需更新apt get即可 xff0c 那么apt get是什么呢 xff1f apt get xff0c 是一条linux命令 xff0
  • ubuntu设置固定ip地址的方法

    ubuntu设置固定ip的方法 问题 xff1a 在连接虚拟机上的mysql数据库时 xff0c 发现连接不上了 检查了数据库的连接信息后 xff0c 发现并没有问题 xff0c 然后去虚拟机上查看ip地址 xff0c 发现是ip地址发生了
  • 在VMware Workstation中ubuntu屏幕小如何解决?-安装vm tools工具

    在VMware Workstation中ubuntu屏幕小如何解决 xff1f 安装vm tools工具 问题 xff1a 安装好ubuntu后 xff0c 开机后发现屏幕太小或没有占满全屏 xff0c 如下图所示 xff1a 解决 xff
  • 美团3.25笔试记录-第一题

    第一题 xff1a 题目描述 xff1a 小美是一个火车迷 最近她在观察家附近火车站的火车驶入和驶出情况 xff0c 发现火车驶入和驶出的顺序并不一致 经过小美调查发现 xff0c 原来这个火车站里面有一个类似于栈的结构 xff0c 如下图
  • Java中的取模(Math.floorMod())与取余(%)

    在Java中运算符 并不是取模运算 Modulo Operation xff0c 而是取余运算 Complementation 那么取模运算和取余运算的区别是什么呢 xff1f 计算方法 对于整数 a b 来说 xff0c 取模运算和取余运
  • redis的持久化策略

    redis提供持久化策略 xff0c 在适当的时机采用适当的手段把内存中的数据持久化到磁盘中 xff0c 每次redis服务启动时 xff0c 都可以把磁盘上的数据再次加载到内存中使用 RDB策略 xff08 数据快照模式 xff09 xf
  • HashMap的7种遍历方式

    HashMap的遍历方式 从大方向来说 xff0c HashMap遍历方式可以分为4类 xff1a 迭代器 xff08 Iterator xff09 方式遍历 xff1b For Each方式遍历 xff1b Lambda表达式遍历 xff
  • C语言中如何计算结构体的大小

    由于存储变量地址对齐的问题 xff0c 计算结构体大小的3条规则 xff1a 结构体的大小由n个 结构体中最大的那个类型 的大小模块组成 xff08 n lt 61 成员个数 xff09 xff1b 一个模块中 xff0c 可以存储多个成员
  • java多线程七大编程题(十分受用)

    前置须知知识 java多线程的实现方式主要由两种 一 创建子类继承Thread类 xff0c 重写run方法 span class token keyword public span span class token keyword cla
  • Java笔记(5)——类的继承、访问控制、super关键字

    在类中 xff0c 不写构造方法 xff0c 相当于执行了默认的无参构造方法 xff1b 写了有参构造方法 xff0c 则只执行有参构造方法 xff0c 默认的无参构造方法则会被屏蔽掉 xff1b 若想拥有有参和无参构造方法 xff0c 则