Java封装继承多态

封装

  • 该露的露,该藏的藏

    • 我们程序设计要追求“高内聚,低耦合”。高内聚就是类的内部数据操作细节自己完成,不允许外部干涉;低耦合:仅暴露少量的方法给外部使用。
  • 封装(数据的隐藏)

    • 通常,应禁止直接访问一个对象中数据的实际表示,而应通过操作接口来访问,这称为信息隐藏。
  • 记住这句话:属性私有(private),get/set

//类    private:私有
public class Student {

    //属性私有
    private String name;  //名字
    private int id;  //学号
    private char sex;  //性别
    private int age;  //年龄

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

    //get:获得这个数据
    public String getName() {
        return this.name;
    }

    //set:给这个数据设置值
    public void setName(String name) {
        this.name = name;
    }

    //alt + insert

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public char getSex() {
        return sex;
    }

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

    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.系统的可维护增加了
 */
public class Application {
    public static void main(String[] args) {
        Student s1 = new Student();

        s1.setName("张三");
        System.out.println(s1.getName());

        s1.setAge(999);  //不合法
        System.out.println(s1.getAge());
    }
}


继承

  • 继承的本质是对某一批类的抽象。

  • extends的意思是“扩展”。子类是父类的扩展。

  • Java中类只有单继承,没有多继承!

  • 继承是类和类之间的一种关系。除此之外,类和类之间的关系还有依赖、组合、聚合等。

  • 继承关系的两个类,一个为子类(派生类),一个为父类(基类)。子类继承父类,使用关键字extends来表示。

  • 子类和父类之间,从意义上讲应该具有“is a”的关系。

  • object类

  • super

  • 方法重写

//在Java中,所有的类,都默认直接或间接继承Object
//父类
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;
    }
}

//派生类:子类
//子类继承了父类,就会拥有父类的全部方法!
//ctrl + H
public class Student extends Person{
}

public class Application {
    public static void main(String[] args) {

        Student student = new Student();
        student.say();
        System.out.println(student.getMoney());
    }


super详解

  • super调用父类的构造方法,必须在构造方法的第一个

  • super必须只能出现在子类的方法或者构造方法中

  • super和this不能同时调用构造方法

  • super和this对比:

    • 前提:

      • this:没有继承也可以用
      • super:只能在继承条件才可以使用
    • 构造方法:

      • this():本类的构造
      • super():父类的构造
    • 代表的对象不同:

      • this:本身调用者这个对象
      • super:代表父类对象的引用
//父类
public class Person {

    public Person() {
        System.out.println("person无参执行了");
    }

    //私有的无法被继承
    public String name = "zhangsan";

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

//子类
public class Student extends Person {

    public Student() {
        //隐藏代码:调用了父类的无参构造

        super(); //默认调用父类的构造器,若显示定义,必须要在子类构造器的第一行
        System.out.println("Student无参执行了");
    }

    private String name = "Mr.zhang";

    public void test(String name) {
        System.out.println(name); //张三
        System.out.println(this.name); //Mr.zhang
        System.out.println(super.name); //zhangsan
    }

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

    public void test1() {
        print(); //student
        this.print(); //student
        super.print(); //person
    }
}

public class Application {
    public static void main(String[] args) {

        Student student = new Student();
        //student.test("张三");
        //student.test1();
    }
}

方法重写

  • 需要有继承关系,子类重写父类的方法
  • 方法名必须相同
  • 参数列表必须相同
  • 修饰符:范围可以扩大但不能缩小:public>protected>default>private
  • 抛出的异常:范围可以缩小,但不能扩大
  • 子类的方法和父类也要一致:方法体不同!
  • 为什么需要重写:父类的功能,子类不一定需要,或者不一定满足!
  • Alt + Insert;override;
  • 以下方法不能被重写:
    • static方法,属于类,它不属于实例
    • final 常量
    • private方法
//重写都是方法的重写,和属性无关
public class B {

    public void test(){
        System.out.println("B=>test()");
    }
}

public class A extends B{

    //Override 重写
    @Override //注解:有功能的注释!
    public void test() {
        System.out.println("A=>test()");
    }
}

        //静态的方法和非静态的方法区别很大!
        //静态方法:方法的调用只和左边,定义的数据类型有关
        //非静态方法:重写
        A a = new A();
        a.test(); //A

        //父类的引用指向了子类
        B b = new A(); // 子类重写了父类的方法
        b.test(); //B
    }
}

多态

  • 动态编译:可扩展性

  • 即同一方法可以根据发送对象的不同而采取多种不同的行为方式

  • 一个对象的实际类型是确定的,但可以指向对象的引用的类型有很多

  • 多态存在的条件:

    • 有继承关系
    • 子类重写父类方法
    • 父类引用指向子类对象
  • 注意:多态是方法的多态,属性没有多态性

public class Person {

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

public class Student extends Person{

    public void run(){
        System.out.println("son");
    }

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

public class Application {
    public static void main(String[] args) {

        //一个对象的实际类型是确定的
        //new student();
        //new Person();

        //可以指向的引用类型就不确定了:父类的引用指向子类
        Student s1 = new Student();  //Student子类能调用的方法都是自己的或者继承父类的
        Person s2 = new Student();  //Person父类,可以指向子类,但是不能调用子类独有的方法
        Object s3 = new Student();

        //对象能执行哪些方法,主要看对象左边的类型,和右边关系不大!
        s2.run();//son 子类重写了父类的方法,执行了子类的方法
        s1.run();
        s1.eat();
    }
}

instanceof和类型转换

public class Application {

    public static void main(String[] args) {

          //Object > String
          //Object > Person > Teacher
          //Object > Person > Student
        
          Object object = new Student();

        //System.out.println(X instanceof Y);//能不能编译通过看X和Y是不是父子关系或X指向的类型和Y有关系

        System.out.println(object instanceof Student); //true
        System.out.println(object instanceof Person); //true
        System.out.println(object instanceof Object); //true
        System.out.println(object instanceof Teacher); //false
        System.out.println(object instanceof String); //false

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

        Person person = new Student();
        
        System.out.println(person instanceof Student); //true
        System.out.println(person instanceof Person); //true
        System.out.println(person instanceof Object); //true
        System.out.println(person instanceof Teacher); //false
        //System.out.println(person instanceof String); //编译报错!

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

        Student student = new Student();
        System.out.println(student instanceof Student); //true
        System.out.println(student instanceof Person); //true
        System.out.println(student instanceof Object); //true
        //System.out.println(student instanceof Teacher); //编译报错!
        //System.out.println(student instanceof String); //编译报错!
    }
}
  • 父类引用指向子类的对象
  • 把子类转换为父类,向上转型
  • 把父类转换为子类,向下转型
  • 方便方法的调用,减少重复的代码,简洁
  • 编程思想:抽象
public class Application {

    public static void main(String[] args) {
        //类型之间的转化:父(高)   子(低) 高转低 > 强制类型转换

        //高                   低
        Person obj = new Student();

        //student将这个对象转换为Student类型,就可以使用Student类型的方法了
        //第一种方法
        Student student = (Student) obj;
        student.go();
        //第二种方法
        ((Student) obj).go();

        //子类转换为父类,可能丢失自己本来的一些方法!
        Student student1 = new Student();
        student1.go();
        Person person = student1; //低转高自动转换

    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值