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

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

 转载自:     

 

1、虚拟机在首次加载Java类时,会对静态初始化块、静态成员变量、静态方法进行一次初始化

2、只有在调用new方法时才会创建类的实例
3、类实例创建过程:按照父子继承关系进行初始化,首先执行父类的初始化块部分,然后是父类的构造方法;再执行本类继承的子类的初始化块,最后是子类的构造方法
4、类实例销毁时候,首先销毁子类部分,再销毁父类部分

复制代码

public class Parent{    public static int t = parentStaticMethod2();    {        System.out.println("父类非静态初始化块");    }    static    {        System.out.println("父类静态初始化块");    }    public Parent()    {        System.out.println("父类的构造方法");    }    public static int parentStaticMethod()    {        System.out.println("父类类的静态方法");        return 10;    }    public static int parentStaticMethod2()    {        System.out.println("父类的静态方法2");        return 9;    }      @Override    protected void finalize() throws Throwable    {        // TODO Auto-generated method stub        super.finalize();        System.out.println("销毁父类");    }    }

复制代码

复制代码

public class Child extends Parent{    {        System.out.println("子类非静态初始化块");    }    static    {        System.out.println("子类静态初始化块");    }    public Child()    {        System.out.println("子类的构造方法");    }    public static int childStaticMethod()    {        System.out.println("子类的静态方法");        return 1000;    }    @Override    protected void finalize() throws Throwable    {        // TODO Auto-generated method stub        super.finalize();        System.out.println("销毁子类");    }}

复制代码

复制代码

public class Test{       public static void main(String[] args)    {        // TODO Auto-generated method stub        Parent.parentStaticMethod();//        Child child = new Child();            }}

复制代码

输出

父类的静态方法2父类静态初始化块父类类的静态方法

类中static 方法在第一次调用时加载,类中static成员按在类中出现的顺序加载。当调用静态方法2时输出

父类的静态方法2父类静态初始化块父类的静态方法2

注释掉Parent.parentStaticMethod();

去掉注释Child child = new Child();

复制代码

父类的静态方法2父类静态初始化块子类静态初始化块父类非静态初始化块父类的构造方法子类非静态初始化块子类的构造方法
你可能感兴趣的文章
Mysql group by
查看>>
MySQL I 有福啦,窗口函数大大提高了取数的效率!
查看>>
mysql id自动增长 初始值 Mysql重置auto_increment初始值
查看>>
MySQL in 太多过慢的 3 种解决方案
查看>>
MySQL InnoDB 三大文件日志,看完秒懂
查看>>
Mysql InnoDB 数据更新导致锁表
查看>>
Mysql Innodb 锁机制
查看>>
MySQL InnoDB中意向锁的作用及原理探
查看>>
MySQL InnoDB事务隔离级别与锁机制深入解析
查看>>
Mysql InnoDB存储引擎 —— 数据页
查看>>
Mysql InnoDB存储引擎中的checkpoint技术
查看>>
Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
查看>>
MySQL InnoDB引擎的锁机制详解
查看>>
Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
查看>>
mysql InnoDB数据存储引擎 的B+树索引原理
查看>>
mysql innodb通过使用mvcc来实现可重复读
查看>>
mysql insert update 同时执行_MySQL进阶三板斧(三)看清“触发器 (Trigger)”的真实面目...
查看>>
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>