zoukankan      html  css  js  c++  java
  • 面向对象特征:继承、多态

    继承

    ·为什么要有继承?

      多个 类中存在相同的属性和行为时,将这些内容抽取到单独一个类中,那么多个类无需再定义这些属性和行为,只要继承那个类即可。

    ·此处的多个类称为子类,单独的这个类称为父类(基类或超类)。可以理解为:子类 is a 父类

    ·类继承语法规则:

    class Subclass extends Superclass{}

    作用:

      继承的出现提高了代码的复用性

      继承的出现让类与类之间产生了关系,提供了多态的前提

      不要仅为了获取其他类中某个功能而去继承

    ·子类继承了父类,就继承了父类的方法和属性

    在子类中,可以使用父类中定义的方法和属性,也可以创建新的数据和方法。

    ·在Java中,继承的关键字用的是“extends”,即子类不是父类的子集,而是对父类的“扩展”。

    关于继承的规则:

      子类不能直接访问父类中私有的(private)的成员变量和方法。

    ·Java只支持单继承,不允许多重继承

      一个子类只能有一个父类

      一个父类可以派生出多个子类

    方法的重写(override)

    ·定义:在子类中可以根据需要对从父类中继承来的方法进行改造,也称方法的重置、覆盖。在程序执行时,子类的方法将覆盖父类的方法。

    ·要求

      重写方法必须和被重写方法具有相同的方法名称、参数列表和返回值类型

      重写方法不能使用比被重写方法更严格的访问权限。

      重写和被重写的方法须同时为static的,或同时为非static的

      子类方法抛出的异常不能大于父类被重写方法的异常

    关键字super

    ·在Java类中使用super来调用父类中的指定操作:

      super可用于访问父类中定义的属性

      super可用于调用父类中定义的成员方法

      super可用于在子类构造方法中调用父类的构造器

    ·注意:

      尤其当子父类出现同名成员时,可以用super进行区分

      super的追溯不仅限于直接父类

      super和this的用法相像,this代表本类对象的引用,super代表父类的内存空间的标识

    调用父类的构造器

    ·子类中所有的构造器默认都会访问父类中空参数的构造器

    ·当父类中没有空参数的构造器时,子类的构造器必须通过this(参数列表)或者super(参数列表)语句指定调用本类或者父类中相应的构造器,且必须放在构造器的第一行

    ·如果子类构造器中既未显式调用父类或本类的构造器,且父类中又没有无参构造器,则编译报错

    this和super的区别

    面向对象特征之:多态性

    ·多态性:是面向对象中最重要的概念,在java中有种体现:

        1.方法的重载(overload)和重写(overwrite)

        2.对象的多态性  --可以直接应用在抽象类和接口上。

    ·Java引用类型有两个类型:编译时类型和运行时类型。编译时类型由声明该变量时使用的类型决定,运行时类型由实际赋给该变量的对象决定。

      若编译时类型和运行时类型不一致,就出现多态(Polymorphism)

    ·对象的多态 -在java中,子类的对象可以替代父类的

        一个变量只能有一种确定的数据类型

        一个引用类型变量可能指向(引用)多种不同类型的对象

    例:

      Person p = new Student();

      Object o = new Person();//Object类型的变量o,指向Person类型的对象

      o = new Student();//Object类型的变量o,指向Student类型的对象

    ·子类可看做是特殊的父类,所以父类类型的引用可以指向子类的对象:向上转型(upcasting)。

    ·一个引用类型变量如果声明为父类的类型,但实际引用的是子类对象,那么该变量就不能再访问子类中添加的属性和方法。

    虚拟方法调用(virtual Method Invocation)

    ·正常的方法调用

      Person e = new Person();

      e.getInfo();

      Student e = new Student();

      e.getInfo();

    ·虚拟方法调用(多态情况下)

      Person e = new Student();

      e.getInfo(); //调用Student类的getInfo()方法

    ·编译时和运行时类型

    编译时e为Person类型,而方法的调用时在运行时确定的,所以调用的是Student类的getInfo()方法。--动态绑定

    多态小结

    ·前提:

      需要存在继承或者实现关系

      要有覆盖操作

    ·成员方法:

      编译时:要查看引用变量所属的类中是否有所调用的方法

      运行时:调用实际对象所属的类中的重写方法

    ·成员变量:

      不具备多态性,只看引用变量所属的类。

    ·子类继承父类

      若子类重写了父类方法,就意味着子类里定义的方法彻底覆盖了父类里的同名方法,系统将不可能把父类里的方法转移到子类中。

      对于实例变量则不存在这样的现象,即使子类里定义了与父类完全相同的实例变量,这个实例变量依然不可能覆盖父类中定义的实例变量

    instanceof操作符

    x instanceof A :检查x是否为类A的对象,返回值为boolean型。

      要求x所属的类与类A必须是子类和父类的关系,否则编译错误。

      如果x属于类A的子类B,x instanceof A 的结果也为true

    对象类型转换(Casting)

    ·基本数据类型的casting:

      自动类型转换:小的数据类型可以自动转换成大得数据

      强制类型转换:可以把大得数据类型强制转换(casting)成小的数据类型

    ·对java对象的强制类型转换称为造型

      从子类到父类的类型转换可以自动进行

      从父类到子类的类型转换必须通过造型(强制类型转换)实现

      无继承关系的引用类型间的转换时非法的

      在造型前可以instanceof操作符测试一个对象的类型

    Object类

    ·object类是所有java类的根父类

    ·如果在类的声明中未使用extends关键字指明其父类,则默认父类为object类

    Object类中的主要方法

    ==比较符与equals方法

    · ==

      基本类型比较值:只要两个变量的值相等,即为true。

      引用类型比较引用(是否指向同一个对象):只有指向同一个对象时,==才返回true。

    用==进行比较时,符号两边的数据类型必须兼容(可自动转换的基本数据类型 除外),否则编译出错;

    ·equals()所有类都继承了Object,也就获得了equals()方法。还可以重写。

      只能比较引用类型,其作用与“==”相同,比较是否指向同一个对象

      格式:Object1.equals(Object2)

    toString()方法

    ·toString()方法在Object类中定义,其返回值是String类型,返回类名和它的引用地址。

    ·在进行String与其他类型数据的连接操作时,自动调用toString()方法

    ·可以根据需要在用户自定义类型中重写toString()方法

    ·基本类型数据转换为String类型时,调用了对应包装类的toString()方法

    包装类

    ·基本数据类型包装成包装类的实例  --装箱

      通过包装类的构造器实现

      还可以通过字符串参数构造包装类对象

    ·获得包装类对象中包装的基本类型变量  --拆箱

      调用包装类的.XXXValue()方法:

    ·JDK1.5之后,支持自动装箱,自动拆箱。但类型必须匹配。

    ·字符串转换成基本数据类型

      通过包装类的构造器实现

      通过包装类的parseXxx(String s)静态方法

    ·基本数据类型转换成字符串

      调用字符串重载的valueOf()方法

      更直接的方式:5+“”

  • 相关阅读:
    理解事件驱动select,poll,epoll三种模型
    谈谈对线程与进程的理解
    5-3.首行缩进
    5-2.行高
    5-1.字间距
    4-6.字体样式重置
    4-5.字体风格
    4-4.字体粗细
    4-3.字体颜色设置
    4-2.字体设置
  • 原文地址:https://www.cnblogs.com/liangxiaoyu/p/5136503.html
Copyright © 2011-2022 走看看