一、一个类的初始化顺序(没继承情况)

 规则:

1.静态变量>普通变量>构造方法

  2.变量定义的顺序决定初始化的顺序

3.静态变量和静态块是一样的,普通变量和非静态块是一样的,即能够把静态块看作是静态变量。把非静态块看作是普通变量

public class Test1 {
public static void main(String[] args) {
new D();
}
} class C{
public C(String s){
System.out.println(s);
}
} class D{
/* D的构造方法 */
public D(){
System.out.println("D的构造方法");
} /* D的非静态变量 */
private C c1 = new C("变量1");
private C c2 = new C("变量2"); /* D的静态变量 */
private static C c3 = new C("静态变量1");
private static C c4 = new C("静态变量2"); /* D的静态初始化块 */
static{
System.out.println("D的静态初始化块。 。");
} /* D的实例初始化块 */
{
System.out.println("D的实例初始化块。。");
}
}

运行结果:

静态变量1

静态变量2

D的静态初始化块。

变量1

变量2

D的实例初始化块。



D的构造方法

二、一个类的初始化顺序(有继承情况)

规则:

  1.父类的初始化>子类的初始化

  2.静态变量>普通变量>构造方法

  3.变量定义的顺序决定初始化的顺序

  4.静态变量和静态块是一样的,普通变量和非静态块是一样的。即能够把静态块看作是静态变量,把非静态块看作是普通变量

public class Test2 {

	public static void main(String[] args) {
new B();
}
} class Feild{
public Feild(String s){
System.out.println(s);
}
} class A{
/* A的构造方法 */
public A(){
System.out.println("父类的构造方法");
} /* A的非静态变量 */
private Feild f1 = new Feild("父类变量1");
private Feild f2 = new Feild("父类变量2"); /* A的静态变量 */
private static Feild f3 = new Feild("父类静态变量1");
private static Feild f4 = new Feild("父类静态变量2"); /* A的静态初始化块 */
static{
System.out.println("父类的静态初始化块。。 ");
} /* A的实例初始化块 */
{
System.out.println("父类的实例初始化块。 。");
}
} class B extends A{
/* B的构造方法 */
public B(){
System.out.println("子类的构造方法");
} /* B的非静态变量 */
private Feild f5 = new Feild("子类变量1");
private Feild f6 = new Feild("子类变量2"); /* B的静态变量 */
private static Feild f7 = new Feild("子类静态变量1");
private static Feild f8 = new Feild("子类静态变量2"); /* B的静态初始化块 */
static{
System.out.println("子类的静态初始化块。。");
} /* B的实例初始化块 */
{
System.out.println("子类的实例初始化块。。");
}
}

运行结果:

父类静态变量1

父类静态变量2

父类的静态初始化块。。

子类静态变量1

子类静态变量2

子类的静态初始化块。。

父类变量1

父类变量2

父类的实例初始化块。。

父类的构造方法

子类变量1

子类变量2

子类的实例初始化块。。

子类的构造方法

以下再看一个样例:

public class Test1 {
public static void main(String[] args) {
new D();
}
} class D{
/* D的构造方法 */
public D(){
System.out.println("D的构造方法");
} public D(String s){
System.out.println(s);
} /* D的非静态变量 */
private static D d1 = new D("变量1");
private static D d2 = new D("变量2"); /* D的静态初始化块 */
static{
System.out.println("D的静态初始化块。 。");
} /* D的实例初始化块 */
{
System.out.println("D的实例初始化块。 。 ");
}
}

输出结果为:

D的实例初始化块。。

变量1

D的实例初始化块。。

变量2

D的静态初始化块。



D的实例初始化块。

D的构造方法

解析:由于new D()时,类D里面会创建两个实例。而又由于静态块的位置在两个实例创建的后面,所以不会先输出静态块的内容。而是创建了两个实例d1、d2后,再new D()。这时才运行静态块、实例块、构造方法。

以下将静态块移到d1和d2创建之前:

public class Test1 {
public static void main(String[] args) {
new D();
}
} class D{
/* D的构造方法 */
public D(){
System.out.println("D的构造方法");
} public D(String s){
System.out.println(s);
} /* D的静态初始化块 */
static{
System.out.println("D的静态初始化块。 。");
} /* D的非静态变量 */
private static D d1 = new D("变量1");
private static D d2 = new D("变量2"); /* D的实例初始化块 */
{
System.out.println("D的实例初始化块。。 ");
}
}

输出结果例如以下:

D的静态初始化块。。

D的实例初始化块。

变量1

D的实例初始化块。。

变量2

D的实例初始化块。。

D的构造方法

Java中类的初始化顺序的更多相关文章

  1. 图示Java类的初始化顺序

    Java类的初始化顺序   在开发中,知道Java类的初始化顺序才能让我们更加清楚地掌握程序的执行流程.先把结论贴出来,Java里,从图里的1~6,分别按顺序执行.   以下为代码验证阶段,一共三个类 ...

  2. java创建对象 的初始化顺序

    java创建对象 的初始化顺序 1.初始化块 初始化块通常写在类的构造方法之前,由花括号括起来,通常包含对成员属性进行初始化的语句: 初始化块分为instance初始化块和static初始化块,初始化 ...

  3. Java学习笔记二十三:Java的继承初始化顺序

    Java的继承初始化顺序 当使用继承这个特性时,程序是如何执行的: 继承的初始化顺序 1.初始化父类再初始子类 2.先执行初始化对象中属性,再执行构造方法中的初始化 当使用继承这个特性时,程序是如何执 ...

  4. java类的初始化顺序

    在java中,当我们new一个对象时,对象中的成员,初始化块以及构造方法的加载是有一定的顺序的,看下面一副图: 一.单类(无基类)下的初始化顺序: public class Parent { stat ...

  5. java中类的初始化和对象的初始化

    静态的属于全局静态区,这个部分独立存在,不管是成员还是块,都是静态的,大家地位相等,先到先得. 然后是成员初始化,这个部分在类的构造函数前初始化,因为编译器(或者设计者)可能认为构造函数调用了这个成员 ...

  6. 【软件构造】-<笔记>-浅谈java中类的初始化过程

    编写java程序时,每创建一个新的对象,都会对对象的内容进行初始化. 每一个类的方法中的局部变量都有严格的初始化要求,因此假如写出下面的程序: void f(){ int i; i++; } 编译时就 ...

  7. [java] java中的初始化顺序

    先看程序: package init_cls; class A{ {System.out.println("i am in the class A!");} static { Sy ...

  8. Java类的初始化顺序 (静态变量、静态初始化块、变量、初始...

    很有意思的一篇文章 1.没有继承 静态变量->静态初始化块->变量->变量初始化块->构造方法 2.有继承的情况 父类静态变量->父类静态初始化块->子类静态变量- ...

  9. Java中的初始化顺序

    一.在创建类时为成员变量赋值和在构造函数中的赋值的先后顺序  在未用构造器之前其实已经将类的字段进行了赋值只是在调用构造器时,又将类的字段进行了重新的赋值.如下: package com.cjm.in ...

随机推荐

  1. 安装Sikulix

    1.sikulix可以在xp,win7,8,10 Mac 10.10.x 以及Linux/Unix 系统上安装 2.安装Java支持 3.下载sikulisetup1.1.0.jar(那里下前篇有介绍 ...

  2. mac配置appium进行自动化测试

    先去brew.sh这个网站,拷贝最新的下载安装命令,黏贴到终端里,回车,按提示下载安装. 安装完毕后,运行brewupdate 看看是否有更新,然后输入brew ios-webkit-debug-pr ...

  3. Java线程同步_1

    Java线程同步_1 synchronized 该同步机制的的核心是同步监视器,任何对象都可以作为同步监视器,代码执行结束,或者程序调用了同步监视器的wait方法会导致释放同步监视器 synchron ...

  4. 在Chrome Console中加载jQuery

    var jq = document.createElement('script'); jq.src = "//ajax.googleapis.com/ajax/libs/jquery/1/j ...

  5. 不定高度的div背景或背景图片不显示问题

    在使用div+css进行网页布局时,如果外部div有背景颜色或者边框,而不设置其高度,在IE浏览器下显示正常.但是使用Firefox/opera浏览时却出现最外层Div的背景颜色和边框不起作用的问题. ...

  6. kali 重置 mysql 密码

    You can recover MySQL database server password with following five easy steps. Step # 1: Stop the My ...

  7. 分析fork后多进程对文件的共享

    fork函数是创建一个新的进程作为原进程的子进程,创建的子进程和父进程存在很多的相似性,首先父子进程的虚拟存储空间的用户空间是相同的,是将父进程的拷贝给子进程.同时父子进程对文件的操作是共享方式.因为 ...

  8. Spark相比Hadoop MapReduce的特点

    (1)中间结果输出     基于MapReduce的计算引擎通常会将中间结果输出到磁盘上,进行存储和容错. 出于任务管道承接的考虑,当一些查询翻译到MapReduce任务时,往往会产生多个Stage, ...

  9. emWin显示文本字符-【worldsing笔记】

    在emWin显示文本字符还是容易的,提供了各种不同的接口,下面是有关于字符显示的常用的用法,可以直接复制到VS2008的模拟ucGui(emWin模拟工程)中运行: 工程代码下载:1.emWin5.2 ...

  10. Perl初识笔记

    前两天项目中遇到了一个Perl脚本程序,需要读懂该程序,由于以前重来没有用过Perl语言,所以没法搞定.今天抽空把该语言的基础看了一遍,基本上内读懂Perl脚本程序了吧.真是如网上很多分享的经验所说, ...