Java初始化生命周期

package com.init;

abstract class Glyph {
void draw() {
System.out.println("Glyph.draw()");
}

Glyph() {
System.out.println("Glyph() before draw()");
draw();
System.out.println("Glyph after draw()");
}
}

class RoundGlyph extends Glyph {

private int radius = 1;

RoundGlyph(int r) {
System.out.println("RoundGlyph.RoundGlyph().radius = " + radius);
radius = r;
System.out.println("RoundGlyph.RoundGlyph().radius = " + radius);
}

void draw() {
System.out.println("RoundGlyph.draw(), radius = " + radius);
}
}

public class PolyConstructors {
public static void main(String[] args) {
new RoundGlyph(5);
}
}

输出:

Glyph() before draw()
RoundGlyph.draw(), radius = 0
Glyph after draw()
RoundGlyph.RoundGlyph().radius = 1
RoundGlyph.RoundGlyph().radius = 5

1  无继承情况下的Java初始化顺序:

class Sample

{

Sample(String s)

{

System.out.println(s);

}

Sample()

{

System.out.println("Sample默认构造函数被调用");

}

}

class Test{

static Sample sam=new Sample("静态成员sam初始化");

Sample sam1=new Sample("sam1成员初始化");

static{

System.out.println("static块执行");

if(sam==null)System.out.println("sam is null");

sam=new Sample("静态块内初始化sam成员变量");

}

Test()

{

System.out.println("Test默认构造函数被调用");

}

}

//主函数

public static void  main(String  str[])

{

Test a=new Test();

}

输出结果为:

静态成员sam初始化     -----静态成员初始化

static块执行          -----静态块被执行

静态块内初始化sam成员变量 ----静态块执行

sam1成员初始化      -----普通成员初始化

Test默认构造函数被调用  -----构造函数执行

由此可以得出结论:

a 静态成员变量首先初始化(注意,Static可以看做一个静态成员,其执行顺序和其在类中申明的顺序有关)

b 普通成员初始化

c 执行构造函数。

对于静态成员(static块可以看成普通的一个静态成员,其并不一定在类初始化时首先执行)和普通成员,其初始化顺序只与其在类定义中的顺序有关,和其他因素无关。

例如下面的例子:

class Test{

static{

System.out.println("static 块 1  执行");

}

static Sample staticSam1=new Sample("静态成员staticSam1初始化");

Sample sam1=new Sample("sam1成员初始化");

static Sample staticSam2=new Sample("静态成员staticSam2初始化");

static{

System.out.println("static 块 2  执行");

}

Test()

{

System.out.println("Test默认构造函数被调用");

}

Sample sam2=new Sample("sam2成员初始化");

}

则结果为:

static 块 1  执行

静态成员staticSam1初始化

静态成员staticSam2初始化

static 块 2  执行

--------静态成员

sam1成员初始化

sam2成员初始化

--------普通成员

Test默认构造函数被调用

--------构造函数

2 Java继承情况下的初始化顺序:

class Test{

static{

System.out.println("父类static 块 1  执行");

}

static Sample staticSam1=new Sample("父类 静态成员staticSam1初始化");

Sample sam1=new Sample("父类 sam1成员初始化");

static Sample staticSam2=new Sample("父类 静态成员staticSam2初始化");

static{

System.out.println("父类 static 块 2  执行");

}

Test()

{

System.out.println("父类 Test默认构造函数被调用");

}

Sample sam2=new Sample("父类 sam2成员初始化");

}

class TestSub extends Test

{

static Sample staticSamSub=new Sample("子类 静态成员staticSamSub初始化");

TestSub()

{

System.out.println("子类 TestSub 默认构造函数被调用");

}

Sample sam1=new Sample("子类 sam1成员初始化");

static Sample staticSamSub1=new Sample("子类 静态成员staticSamSub1初始化");

static{System.out.println("子类 static 块  执行");}

Sample sam2=new Sample("子类 sam2成员初始化");

}

执行结果:

父类 static 块 1  执行

父类 静态成员staticSam1初始化

父类 静态成员staticSam2初始化

父类 static 块 2  执行

--------父类静态成员初始化

子类 静态成员staticSamSub初始化

子类 静态成员staticSamSub1初始化

子类 static 块  执行

-------子类静态成员初始化

父类 sam1成员初始化

父类 sam2成员初始化

父类 Test默认构造函数被调用

-------父类普通成员初始化和构造函数执行

子类 sam1成员初始化

子类 sam2成员初始化

子类 TestSub 默认构造函数被调用

-------父类普通成员初始化和构造函数执行

由此得出Java初始化顺序结论:

1 继承体系的所有静态成员初始化(先父类,后子类)

2 父类初始化完成(普通成员的初始化-->构造函数的调用)

3 子类初始化(普通成员-->构造函数)

Java初始化顺序如图:

时间: 2024-08-05 12:00:31

Java初始化生命周期的相关文章

java类生命周期详细解析

(一)详解java类的生命周期 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大多只是告诉你“怎样做”,但至于“为什么这样做”却不多说,所以造成大家在基础和原理方面的知识比较匮乏,所以笔者今天就斗胆来讲一下这个问题,权当抛砖引玉,希望对在这个问题上有疑惑的朋友有所帮助,文中有说的不对的地方,也希望各路高手前来指正. 首先来了解一下jvm(java虚拟机)

hibernate session缓存和java对象生命周期

一.java对象生命周期 1.在java中,使用new关键字,创建一个java对象,jvm就为这个对象分配一块内存空间.只要这个变量被引用,他就一直存在于内存中.如果没有被任何变量引用(包括间接引用),那么这个对象就会被垃圾回收器回收.下面用一段代码来解释: Customer c=new Customer(); Order o1=new Order(); Order 02=new Order(); o1.setCustomer(c); c.getOrders().add(o1); o1=null

Java学习之==>Java线程生命周期与状态切换

一.Java线程生命周期与状态切换 这些状态的描述可以总结成下图: NEW 一个刚创建但尚未启动的Java线程实例就是处于 NEW 状态 public class App { public static void main(String[] args) { Thread thread = new Thread(); Thread.State state = thread.getState(); System.out.println(state); } } // 输出结果 NEW RUNNABLE

Java实现生命周期管理机制

先扯再说 最近一直在研究某个国产开源的MySQL数据库中间件,拉下其最新版的代码到eclipse后,启动起来,然后做各种测试和代码追踪:用完想要关闭它时,拉出它的STOP类想要运行时,发现这个类里赫然只写以下几行代码,于是我感觉瞬间受到了很多伤害. public static void main(String[] args) { System.out.println(new Date() + ",server shutdown!"); } 这个中间件启动和运行的时候,开启了监听,启动着

java对象生命周期

java中一个对象的完整生命周期涉及java平台的很多技术.在创建一个java对象之前,需要先由虚拟机加载该类,然后对该java类进行链接和初始化.初始化完成之后,才创建出该类的对象实例.java对象也有自己的初始化过程,主要通过构造方法完成.当不再有引用指向该对象时,对象占用的内存会在合适的时机被垃圾回收器回收.对象终止机制提供了一种方式在对象被回收之前进行清理工作. java类的链接 虚拟机刚启动时,内部只包含java核心类的相关信息.随着程序的运行,不断有新的java类被加载到虚拟机中.j

Java WebSocket生命周期

本章将讲述WebSocket端点的生命周期.WebSocket端点的生命周期为开发人员提供了一个框架来管理端点所需要的资源,也提供了一个框架来拦截消息.我们将仔细探讨其生命周期的顺序和语义,以及Java WebSocket API如何提供API和注解来支持处理这些事件. 一.WebSocket协议 与基于HTTP的技术不同,WebSocket具有生命周期.此生命周期周期由WebSocket协议支撑.WebSocket协议定义了客户端和服务器长时间存活的专用的TCP连接,一旦连接已经建立,数据的传

Java多线程生命周期

这两天在看线程的东西,根据牛人的博客总结了一些:每个Java程序至少包含一个线程:主线程.其它线程都是通过Thread构造器或实例化继承类Thread的类来创建的.正在运行的线程通常是由操作系统创建的:Thread对象是由JavaVM创建的,在一个线程对新线程的Thread对象调用start()方法之前,这个新线程并没有真正开始执行.Thread对象在其线程真正启动之前就已经存在了,而且其线程退出之后仍然存在.另外需要说明的是:run()方法只是一个类中的普通方法,直接执行和普通的方法没有两样:

Java 线程生命周期

2.线程的生命周期 与人有生老病死一样,线程也同样要经历开始(等待).运行.挂起和停止四种不同的状态.这四种状态都可以通过Thread类中的方法进行控制.下面给出了Thread类中和这四种状态相关的方法. // 开始线程 publicvoid start( ); publicvoid run( ); // 挂起和唤醒线程 publicvoid resume( );     // 不建议使用 publicvoid suspend( );    // 不建议使用 publicstaticvoid s

java static 生命周期和作用域

类的成员变量有两种:一种是被static关键字修饰的变量,叫类变量或静态变量,一种是没有被static修饰的,叫做实例变量 在语法定义上的区别:静态变量前要加static关键字,而实例变量前则不加. 在程序运行时的区别:实例变量属于某个对象的属性,必须创建了实例对象,其中的实例变量才会被分配空间,才能使用这个实例变量. 静态变量不属于某个实例对象,而是属于类,所以也称为类变量,只要程序加载了类的字节码,不用创建任何实例对象 静态变量就会被分配空间,静态变量就可以被使用了.总之,实例变量必须创建对