博客
关于我
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父类静态初始化块子类静态初始化块父类非静态初始化块父类的构造方法子类非静态初始化块子类的构造方法
你可能感兴趣的文章
netcat的端口转发功能的实现
查看>>
netfilter应用场景
查看>>
netlink2.6.32内核实现源码
查看>>
Netpas:不一样的SD-WAN+ 保障网络通讯品质
查看>>
NetScaler的常用配置
查看>>
netsh advfirewall
查看>>
NETSH WINSOCK RESET这条命令的含义和作用?
查看>>
Netty WebSocket客户端
查看>>
netty 主要组件+黏包半包+rpc框架+源码透析
查看>>
Netty 异步任务调度与异步线程池
查看>>
Netty中集成Protobuf实现Java对象数据传递
查看>>
Netty事件注册机制深入解析
查看>>
Netty原理分析及实战(四)-客户端与服务端双向通信
查看>>
Netty客户端断线重连实现及问题思考
查看>>
Netty工作笔记0006---NIO的Buffer说明
查看>>
Netty工作笔记0007---NIO的三大核心组件关系
查看>>
Netty工作笔记0011---Channel应用案例2
查看>>
Netty工作笔记0013---Channel应用案例4Copy图片
查看>>
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>