Java学习日记(十一)封装继承多态

Java学习日记(十一)封装继承多态

封装

该露的露,该藏的藏

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

封装

通常,应禁止直接访问一个对象中数据的实际表示,而应通过操作接口来访问,这称为信息隐藏。

记住:属性私有,get/set

package oop.Demo;

//类  private:私有
public class Person {
    private String name;
    private int id;
    private char sex;

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

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

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

/*
* 1.提高程序的安全性,保护数据
* 2.隐藏代码的实现细节
* 3.统一接口
* 4.系统可维护增加了*/
public class Demo01 {
    public static void main(String[] args) {
        Person shengyi = new Person();
        shengyi.setName("shengyi");
        System.out.println(shengyi.getName());
    }
}

继承

  • 继承的本质是对某一批类的抽象,从而实现对现实世界更好的建模。
  • extends的意思是“扩展”。子类是父类的扩展。
  • Java中类只有单继承,没有多继承。
  • 继承是类和类之间的一种关系,除此之外,类和类之间的关系还有依赖,组合,聚合等。
  • 继承关系的两个类,一个为子类(派生类),一个为父类(基类)。子类继承自父类,使用关键字extends来表示。
  • 子类和父类自检,从意义上讲应该具有“is a”的关系。
  • 所有类都默认继承自Object。
  • super
  • 方法重写
package oop.Demo;

// 使用extends可以实现继承
public class Student extends Person{
}

这里的Student就继承了Person中的所有方法以及非私有属性,私有的都无法继承

package oop.Demo;

//类  private:私有
public class Person {
    public String name = "Cheng";

    public Person() {
        System.out.println("父类无参构造");
    }
    public void print() {
        System.out.println("Person");
    }
}

package oop.Demo;

// 使用extends可以实现继承
public class Student extends Person{
    public String name = "shengyi";

    public Student() {
        super();//隐藏代码,一定是放在子类构造器第一行的
        System.out.println("子类无参构造");
    }
    public void print() {
        System.out.println(this.name);
        System.out.println(super.name);
    }
}
package oop.Demo;

public class Demo01 {
    public static void main(String[] args) {
        Student student = new Student();
//        student.print();
    }
}

在继承的时候,子类的构造一定是在父类构造之后。

不写super是默认调用父类的无参构造,如果要使用有参的话一定要显示定义一个有参构造。

  • 小总结:

    • super注意点:

      • super调用父类的构造方法,必须在构造方法的第一个。
      • super必须只能出现在子类的方法或构造方法中。
      • super和this不能同时调用构造方法。
    • Vs this:

      • 代表对象不同:this本身调用者这个对象。super代表父类对象的应用。
      • 前提:this没有继承也可以使用。super只有在继承条件才可以使用。
      • 构造方法:this();本身的构造。super();父类的构造。

重写

package oop.Demo;

public class B {
    public static void test() {
        System.out.println("B");
    }
}
package oop.Demo;

public class A extends B{
    public static void test() {
        System.out.println("A");
    }
}
package oop.Demo;

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

        //方法的调用只和左边,定义的数据类型有关
        A a = new A();
        a.test();//A

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

注意!!!!

test方法是一个静态方法不是重写,与下面的非静态方法对比一下。

package oop.Demo;

public class B {
    public  void test() {
        System.out.println("B");
    }
}
package oop.Demo;

public class A extends B{
    public  void test() {
        System.out.println("A");
    }
}
package oop.Demo;

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

        //方法的调用只和左边,定义的数据类型有关
        A a = new A();
        a.test();//A

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

静态方法不算重写,第二个才是重写

  • 重写:需要有继承关系,子类重写父类的方法!
    • 方法名必须相同
    • 参数列表必须相同
    • 修饰符:范围可以扩大但不能缩小:public>Protected>Default>private
    • 抛出异常:范围,可以缩小,但不能扩大;ClassNotFoundException–>Exception(大)

重写,子类的方法和父类必要一致;方法体不同!

为什么需要重写:

    • 父类的功能,子类不一定需要,或者不一定满足!

多态

  • 既同一方法可以根据发送对象的不同而采用多种不同的行为方式。
  • 一个对象的实际类型是确定的,但可以指向对象的引用类型有很多
  • 多态存在的条件
    • 有继承关系
    • 子类重写父类放法
    • 父类引用指向子类对象
  • 注意:多态是方法的多态,属性没有多态性。
  • instanceof (类型转换)引用类型,判断一个对象是什么类型
package oop0.Demo;

public class Person {
    public void say() {
        System.out.println("人类说");
    }
}
package oop0.Demo;

public class Student extends Person {
    public void say() {
        System.out.println("学生说");
    }

    public void run() {
        System.out.println("学生跑");
    }
}
package oop0.Demo;

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

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

        //可以指向的引用类型就不确定了;父类的引用指向子类

        //Student  能调用的方法都是自己的或者是继承父类的
        Student s1 = new Student();
        //Person 父类型,可以指向子类,但是不能调用子类独有的方法
        Person s2 = new Student();//如果右边new 是一个Person 那s1.say();输出的就是人类说
        Object s3 = new Student();

        //对象能执行那些方法,主要看左边的类型,和右边的关系不打
        //s2.run();  这句代码就报错了,s2的左边是Person类型,没有run这个方法,虽然右边的Student有这个方法,但是不会执行
        s1.run();//学生跑
        s1.say();//学生说
        s2.say();//学生说
    }
}

注意事项:

  • 堕胎是方法的多态,属性没有多态
  • 父类和子类,有联系 类型转换异常! ClassCastException!
  • 存在条件:继承关系,方法需要重写,父类的引用指向子类对象! Father f1 = new Son();
    • static 方法,属于类,它不属于实例
    • final 常量
    • private方法

instanceof和类型转换

package oop0.Demo;

public class Person {
    public void say() {
        System.out.println("人类说");
    }
}
package oop0.Demo;

public class Student extends Person {
    public void run() {
        System.out.println("跑");
    }
}
package oop0.Demo;

public class Teacher extends Person{
}
package oop0.Demo;

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);能不能编译通过!看Y是不是X的子类型
//
//        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);//编译报错

        //类型之间的转化:  父     子
        //高                  低
        Person obj = new Student();
        //student将这个对象转换为Student类型,我们就可以使用Student类型的方法了!

//        Student student = (Student) obj;
//        student.run();

        ((Student)obj).run();

        //子类转换成父类可能丢失自己本来的一些方法
        Student student = new Student();
        student.run();
        Person person = student;
//        person.run();//报错
    }
}

小总结:

  • 父类引用指向子类的对象
  • 把子类转换成父类,向上转型
  • 把父类转换成子类,向下转型;强制转换
  • 方便方法的调用,减少重复的代码;简介

封装 继承 多态 抽象类,接口

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值