博客
关于我
java 中类的加载顺序
阅读量:111 次
发布时间:2019-02-26

本文共 1358 字,大约阅读时间需要 4 分钟。

Java 类的初始化与销毁机制是程序运行的重要组成部分,理解其工作原理对于优化程序性能至关重要。本文将从静态初始化、实例创建、类销毁等方面详细解析 Java 的类生命周期。

1. 静态初始化与类加载

在 Java 中,静态初始化是类加载的关键环节。第一次加载类时,Java 虚拟机(JVM)会执行以下步骤:

  • 静态成员变量初始化:将所有静态变量初始化为其定义时的值。
  • 静态初始化块:执行所有静态初始化块。这类似于类构造过程中执行初始化操作,但仅在类被首次加载时执行。
  • 静态方法调用:如果静态方法在类加载时被调用,则会立即执行这些方法。

例如,在 Parent 类中:

public static int t = parentStaticMethod2();{    System.out.println("父类非静态初始化块");}static{    System.out.println("父类静态初始化块");}

当 Parent 类被首次加载时,jvm 会执行父类的静态初始化块,并按顺序调用静态方法。

2. 实例创建与类初始化

当使用 new 运算符创建类实例时,类的实例创建过程遵循以下顺序:

  • 父类初始化
    • 执行父类的非静态初始化块。
    • 调用父类的构造方法(super())。
  • 子类初始化
    • 执行子类的非静态初始化块。
    • 调用子类的构造方法(this())。
  • 例如,Child 类继承 Parent 类:

    {    System.out.println("子类非静态初始化块");}

    当创建 Child 实例时,jvm 会先初始化 Parent 类的非静态部分,再初始化 Child 的非静态部分。

    3. 类销毁与内存管理

    类实例销毁时,JVM 会执行以下步骤:

  • 子类销毁:首先销毁子类的非静态部分。
  • 父类销毁:接着销毁父类的非静态部分。
  • 静态成员销毁:如果类没有任何实例存在,JVM 会销毁其静态成员变量和静态初始化块。
  • 例如,Parent 类的 finalize() 方法:

    @Overrideprotected void finalize() throws Throwable{    super.finalize();    System.out.println("销毁父类");}

    当 Child 实例被销毁时,JVM 会先调用 Child 的 finalize(),再调用 Parent 的 finalize()

    4. 实际应用示例

    通过 Test 类的 main 方法:

    public static void main(String[] args){    Parent.parentStaticMethod2();    Child child = new Child();}

    运行结果如下:

    父类的静态方法2父类静态初始化块父类的静态方法2子类静态初始化块父类非静态初始化块父类的构造方法子类非静态初始化块子类的构造方法

    这表明,类的初始化顺序是:

  • 父类静态初始化块
  • 子类静态初始化块
  • 父类非静态初始化块
  • 子类非静态初始化块
  • 父类构造方法
  • 子类构造方法
  • 通过以上分析,可以清晰地看出 Java 类的生命周期及其初始化和销毁的具体过程。理解这些机制有助于优化程序性能,避免内存泄漏和资源浪费。

    转载地址:http://wbof.baihongyu.com/

    你可能感兴趣的文章
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>
    Oracle中常用的语句
    查看>>
    Oracle中序列的操作以及使用前对序列的初始化
    查看>>
    oracle中新建用户和赋予权限
    查看>>
    Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
    查看>>
    Oracle中的rownum 和rowid的用法和区别
    查看>>
    oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
    查看>>
    oracle中表和视图的区别,oracle中常用表和视图
    查看>>
    oracle从备份归档日志的方法集中回收
    查看>>