博客
关于我
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父类静态初始化块子类静态初始化块父类非静态初始化块父类的构造方法子类非静态初始化块子类的构造方法
你可能感兴趣的文章
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>