JavaSE面向对象02 2021.05.11-12

本文深入讲解Java中的封装和继承两大核心概念,探讨如何通过封装提高程序安全性及代码维护性,并通过实例演示如何实现继承,揭示继承的本质及其在现实世界建模中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

效率还是有点低呀,可能听课第一遍不够透彻,需要看多几次,造成时间的成倍浪费,确实要好好调整一下
加油!

在这里插入图片描述

1 封装

封装大多数时候是对于属性,对于方法用得比较少

  • 该露的露,该藏的藏
    程序设计要追求“高内聚,低耦合”。高内聚就是类的内部数据操作细节自己完成,不允许外部干涉;低耦合就是仅暴露少量的方法给外部使用。
  • 封装(数据的隐藏)
    通常,应禁止直接访问一个对象中数据的实际表示,而应通过操作接口来访问,这称为信息隐藏

属性私有 (private),get/set (方法操作)

//get 获得这个数据
//set 给这个数据设置值
    public static void main(String[] args) {
        Student s1 = new Student();
        s1.setName("beckham");
        System.out.println(s1.getName());// beckham
    }


public class Student {
    //属性私有 private
    private String name;//名字

    //提供一些可以操作这个属性的方法!
    //提供一些 public 的 get、set方法

    //get 获得这个数据
    public String getName(){
        return this.name;
    }
    
    //set 给这个数据设置值
    public void setName(String name){
       this.name=name;
    }
}

生成get、set方法 快捷键 alt+inset

步骤如下:
①按下快捷键alt+insert,选中Getter and Setter
在这里插入图片描述
②选中要生成的属性
在这里插入图片描述
③生成get、set方法
在这里插入图片描述

规避不合法的数据,封装做安全性的检查:

    public static void main(String[] args) {
        s1.setAge(18);
        System.out.println(s1.getAge());// 18
        s1.setAge(130);//不合法
        System.out.println(s1.getAge());// 3
    }


public class Student {

    //属性私有 private
    private int age;//年龄

    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        if (age>=0 && age<=120){
            this.age = age;
        }else{
            this.age=3;
        }
    }
}

封装的作用

  1. 提高程序的安全性,保护数据
  2. 隐藏代码的实现细节
  3. 统一接口
  4. 增加系统可维护性

//题外话:方法的重载:方法名相同,参数列表相同----> 同一个方法

2 继承

  • 继承的本质是对某一批类的抽象,从而实现对现实世界的更好的建模。(对类再进行抽象)
  • extends的意思是“扩展”。子类是父类的扩展
  • Java中类只有单继承,没有多继承
  • 继承是类和类之间的一种关系。除此之外,类和类之间的关系还有依赖,组合,聚合等。
  • 继承关系的俩个类,一个为子类(派生类),一个为父类(基类)。子类继承父类,使用关键字extends来表示。
  • 子类和父类之间,从意义上讲应该具有“is a”的关系。

一个父类可以有多个子类,一个子类只能有一个父类

//父类
public class Person {
}
//子类:Teacher is Person
public class Teacher extends Person {
}
//子类:Student is Person
public class Student extends Person {
}

实现这个事情也有其他方法如 组合:

public class Student {
    Person person;
}

子类继承父类,拥有父类的全部方法和属性。

前提是修饰符 public
修饰符为private,就不可继承,私有不可继承

public class Person {
    public int money = 10_0000_0000;
    public void say(){
        System.out.println("说了一句话");
    }
}

public class Student extends Person {

}
public class Application {
    public static void main(String[] args) {
        Student student = new Student();
        
        student.say();// 说了一句话
        System.out.println(student.money);//1000000000
    }
}

四个修饰符,优先级由高到低如下:

public
protected 受保护的
default 默认,一般不写修饰符默认为default
private 私有的

一般属性是私有的,所以:

public class Person {
    private int money = 10_0000_0000;
    public void say(){
        System.out.println("说了一句话");
    }

    public int getMoney() {
        return money;
    }
    public void setMoney(int money) {
        this.money = money;
    }
}

public class Student extends Person {

}

public class Application {
    public static void main(String[] args) {
        Student student = new Student();

        student.say();// 说了一句话

        student.setMoney(100);
        System.out.println(student.getMoney());//100
    }
}

Object类

打开继承关系 快捷键 Ctrl+H:
发现有一个Object类
在这里插入图片描述
清空Person类的方法,发现有这么多的方法但是之前没有定义过的,这些方法其实是继承Object类的。
在这里插入图片描述
所以,在Java中,所有的类,都默认直接或间接继承Object类

没有显示定义继承Object类,但还是默认继承了这个类

public class Person /*extends Object */ {

}

super

注意点:
1.super调用父类的构造方法,必须在构造方法的第一个
2.super必须只能出现在子类的方法或者构造方法中
3.super和this不能同时调用构造方法

this:
1.本身调用者这个对象
2.没有继承也可以使用
3.this();本类的构造;

super:
1.代表父类对象的应用
2.只能在继承条件才可以用
3.super();父类的构造;

public class Person /*extends Object */ {
    protected String name="beckham";

    public void print(){
        System.out.println("Person");
    }
}

public class Teacher extends Person {
    private String name="bixian";
    public void print (){
        System.out.println("Student");
    }
    public void test(String name){
        System.out.println(name);
        System.out.println(this.name);
        System.out.println(super.name);
    }
    public void test1(){
        print();
        this.print();
        super.print();
    }

}

public class Application {
    public static void main(String[] args) {
        Teacher teacher = new Teacher();
        
        teacher.test("碧咸");
        //碧咸
        //bixian
        //beckham
        
        teacher.test1();
        //Student
        //Student
        //Person
    }
}

隐藏代码:构造器默然调用了父类的无参构造

    public Teacher() {
        super();//调用父类的构造器,必须要在子类构造器的第一行
        System.out.println("Student无参构造执行");
    }
public class Person /*extends Object */ {
    public Person() {
        System.out.println("Person无参构造执行");
    }
}

public class Teacher extends Person {
    public Teacher() {
        System.out.println("Student无参构造执行");
    }
}

public class Application {
    public static void main(String[] args) {
        Teacher teacher = new Teacher();
        /*
        Person无参构造执行
        Student无参构造执行
        */
    }
}

假设调用自己的构造器,比如子类的有参构造

    public Teacher() {
        super();
        this("hi");// 这里会标红
        System.out.println("Student无参构造执行");
    }

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

调用子类构造器也必须要在第一行,所以要么调用子类要么调用父类构造器。


  • 问题:
    如果父类没有无参构造,比如定义了有参而没有定义无参,这时就会因为子类默认调用父类的无参而调用不了
  • 方法:
    这时让子类构造器调用父类的有参构造就可以了。
  • 注意事项:
    但是一般定义了有参就要定义无参,就不会出现错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值