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

 规则:

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. <测试用例设计>用户及权限管理功能常规测试方法

    1)  赋予一个人员相应的权限后,在界面上看此人员是否具有此权限,并以此人员身份登陆,验证权限设置是否正确(能否超出所给予的权限): 2)  删除或修改已经登陆系统并正在进行操作的人员的权限,程序能否 ...

  2. 对web日志文件实现按照人员、行为分类

    日志格式: method,time,name in,2015-05-06 17:37:46,Jenny1out,2015-05-06 17:37:46,Judith1in,2015-05-06 17: ...

  3. strtok和strtok_r

    1.strtok()函数的用法 函数原型:char *strtok(char *s, const char *delim); Function:分解字符串为一组字符串.s为要分解的字符串,delim为 ...

  4. 整理string类常见方法的使用说明

    整理String类的Length().charAt().getChars().replace().toUpperCase().toLowerCase().trim().toCharArray()使用说 ...

  5. .NET中的Newtonsoft.Json.JsonConvert.SerializeObject(string a)

    1.將string a 序列化為Json格式: 2.使用條件:將Newtonsoft.Json.dll作為引用添加到項目中.下载地址在这:http://json.codeplex.com/

  6. iOS9对SDK的影响(iOS9适配必看)

      1.大部分社交平台接口不支持https协议. 问题描述:在iOS9下,系统默认会拦截对http协议接口的访问,因此无法获取http协议接口的数据.对ShareSDK来说,具体表现可能是,无法授权. ...

  7. CircleLayout

    CircleLayout https://developer.apple.com/library/ios/samplecode/CircleLayout/Introduction/Intro.html ...

  8. jq 弹出窗口

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  9. dom 优酷得弹出

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  10. rhel及相关linux系统版本知识

    Rhel 此处Rhel非等同redhat哦,RedHat是红帽公司在1994年左右开发维护的linux桌面版本,在2004年左右红帽公司放弃redhat开始进军linux服务器版本开发,具体见下截图 ...