JAVA基础-继承机制

需要掌握的知识点:

  1. 包的使用
  2. 继承时,子类如何覆盖父类方法(重写和重载)
  3. 继承时,构造方法的执行过程
  4. JVM中子类如何实例化(先实例化父,再实例化子)
  5. super和this关键字
  6. final关键字

包的导入

import java.util.Scanner;

public class PackageTest {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        sc.nextInt();
    }
}

Object类是所有类的鼻祖

当没有任何显示的继承类时,默认继承 java.lang
包下的Object类

//object源码中一些比较常用的方法

    public boolean equals(Object obj) {  //引用比较
        return (this == obj);
    }

    //返回类名加hashcode
    public String toString() {
        return getClass().getName() + "@" + Integer.toHexString(hashCode());
    }

    public final native Class<?> getClass();  //返回类名

访问修饰符权限

访问修饰符 同类 同包 子类 其他
public
protected
默认
private

其中protected含义是保护继承的子类,这样在不同的包中就可以让子类访问了。

使用super关键字,super代表父类对象

  • 访问父类构造方法

    super();
    super(name);
  • 访问父类属性

    super.age;
    super.name;
  • 访问父类方法

    super.print();

    总结一下super和this 的区别

—- —- —- —-
this访问本类构造方法 必须第一行 本类属性 本类方法 this可以引用当前对象
super访问父类构造方法 必须第一行 父类属性 父类方法 super只能出现在子类中

方法重写

  • 子类方法必须和父类具有相同的方法名称、参数列表和返回值类型(Eclipse中快捷键ALT+/可以快速重构父类函数)
  • 子类方法的访问权限只能大于等于父类
  • 子类方法抛出的异常不能大于父类被重写的异常

对象的创建过程

  1. JVM会先加载父类,再加载子类
  2. 在栈内存中为定义的变量分配内存空间,同时在堆内存中为真正的对象分配内存空间
  3. 调用构造器来为创建出的对象进行初始化
    1. 子类中所有的构造方法, 默认
      都会先调用父类中 无参
      的构造方法 (如果父类中没有无参的构造方法,那么在子类中要利用super手动添加一个父类的有参构造方法)
    2. Object类的构造器是最先被执行的

final 关键字

  1. final修饰类表示该类不能被继承

    比如String类就是这种情况

  2. final修饰变量

    1. 表示该变量只能被赋值一次
    2. 成员变量、局部变量都可以使用final修饰(其中成员变量必须在声明时赋值或者通过构造方法赋值,变成一个常量。局部变量可以不在声明的时候赋值,但是也只能赋值一次)
    3. 必须手工为变量赋值一次(包括成员变量,如果赋默认值,没有任何意义)
  3. final修饰方法表示该方法不能被子类重写

原文 

http://www.cnblogs.com/JeasonIsCoding/p/13232452.html

本站部分文章源于互联网,本着传播知识、有益学习和研究的目的进行的转载,为网友免费提供。如有著作权人或出版方提出异议,本站将立即删除。如果您对文章转载有任何疑问请告之我们,以便我们及时纠正。

PS:推荐一个微信公众号: askHarries 或者qq群:474807195,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

转载请注明原文出处:Harries Blog™ » JAVA基础-继承机制

赞 (0)
分享到:更多 ()

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址