前言
今天在看android contentprovider实现的时候,突然想到了java类在new的过程中,静态域、静态块、非静态域、非静态块、构造函数的执行顺序问题。其实这是一个很经典的问题,非常考察对java基础知识的掌握程度。很多面试过程中相信也有这样的问题,趁着周末有时间复习一下。
结论
这里先把整理好的结论抛给大家,然后我在写个程序来验证我们的结论。在java类被new的过程中,执行顺序如下:
在实现继承的类被new的过程中,初始化执行顺序如下:
这里需要简单的介绍一下静态代码块和非静态代码块。
1. 静态代码块:
static {
}
2. 非静态代码块
{
}
静态代码块和非静态代码块的异同点如下:
验证
对于结论的最好验证就是写出代码来进行结果证明。首先,来看一下无继承的类初始化时的执行顺序,代码如下:
public class initodertest { public static string static_field = "静态属性"; // 静态块 static { system.out.println(static_field); system.out.println("静态代码块"); } public string field = "非静态属性"; // 非静态块 { system.out.println(field); system.out.println("非静态代码块"); } public initodertest() { system.out.println("无参构造函数"); } public static void main(string[] args) { initodertest test = new initodertest(); } }
执行结果:
接下来,我们验证一下,当java类实现继承后,执行顺序是否和我们的结论吻合。测试代码如下:
class parenttest { public static string parent_static_field = "父类-静态属性"; // 父类-静态块 static { system.out.println(parent_static_field); system.out.println("父类-静态代码块"); } public static string parentfield = "父类-非静态属性"; // 父类-非静态块 { system.out.println(parentfield); system.out.println("父类-非静态代码块"); } public parenttest() { system.out.println("父类—无参构造函数"); } } public class initodertest extends parenttest { public static string static_field = "静态属性"; // 静态块 static { system.out.println(static_field); system.out.println("静态代码块"); } public string field = "非静态属性"; // 非静态块 { system.out.println(field); system.out.println("非静态代码块"); } public initodertest() { system.out.println("无参构造函数"); } public static void main(string[] args) { initodertest test = new initodertest(); } }
执行结果如下:
如对本文有疑问, 点击进行留言回复!!
集合框架——Map、泛型以及Collection算法常用方法
Elasticsearch 升级 7.x 版本后,我感觉掉坑里了
Mybatis的插件运行原理以及如何编写一个Mybatis的插件
网友评论