类的生命周期

综述

1.    只有当一个类被切实使用到的时候才会被加载到虚拟机中(例如:new, 方法调用, A a = null;不算)

2.    若在加载一个类的过程中,有其他类被切实使用到,则会被一同级联加载到JVM中。

3.    当一个类中的某个符号被第一次使用到时,该类才会被初始化;当类被加载时,它并未被初始化。

4.    初始化顺序:

静态函数/变量初始化(Textual Order)

实例成员变量初始化

构造函数

加载(Loading)

1)类加载器通过类的全限定名来获取定义此类的二进制字节流

2)字节流-> 方法区运行时数据结构

3)在方法区生成java.lang.Class 对象 (作为这个类在方法区的入口)

验证 (Verification)

确保Class字节流中包含的信息符合当前JVM的要求,且不会危害虚拟机安全

1)文件格式验证 (验证字节流是否符合Class文件格式规范)

2)元数据验证(对元数据进行语义校验,确保符合Java语法)

3)字节码验证(对类的方法体进行校验,确保符合语义和逻辑)

4)符合引用验证(对类中的符号引用进行校验,以确保解析动作可正常执行)

准备(Preparation)

为类变量的静态字段在方法区分配内存并设置零值的阶段

1.   进行内存分配的对象仅包括类变量的static字段

2.  初始化的为变量的零值,而非默认值

解析(Resolution)

JVM将常量池内的符号引用替换为直接引用的过程,包括

类/接口、字段、类方法、接口方法、方法类型、方法句柄、调用点限定符

初始化(Initialization)

执行<clinit>()方法的过程

1.     <clinit>()方法是由类变量的赋值动作和static语句块合并产生的;合并后的顺序即自然语句顺序(Textual Order);static语句块只能访问定义在该语句块之前的变量,定义在其后的变量只能赋值,不能访问。

2.     JVM自动在子类<clinit>()方法执行之前,先执行父类<clinit>()方法

3.    若类中没有静态语句块,也没有对变量的赋值操作,则compiler可以不生成<clinit>()方法

4.    执行接口的<clinit>()方法前不需要先执行父接口的<clinit>()方法,当需要使用到父接口定义的变量时,再行初始化。

5.    接口的实现类在初始化时不会执行父接口<clinit>()方法

6.    JVM保证一个类的<clinit>()方法运行时是线程安全的;但是如果执行<clinit>()的线程退出该方法,其它线程被唤醒后不会再进入<clinit>(),即:一个类加载器下,每个类型只会被初始化一次。

Reference:

https://docs.oracle.com/javase/specs/jvms/se6/html/ClassFile.doc.html#9766

http://www.programcreek.com/2013/01/when-and-how-a-java-class-is-loaded-and-initialized/

http://www.programcreek.com/2011/10/java-class-instance-initializers/

http://stackoverflow.com/questions/7560721/when-does-the-jvm-load-classes

JVM:类的生命周期的更多相关文章

  1. JVM 类的生命周期、类加载器

    类的加载.连接与初始化                  • 1. 加载:查找并加载类的二进制数据         • 2. 连接             – 2.1 验证:确保被加载的类的正确性   ...

  2. Java - JVM - 类的生命周期

    概述 简述 JVM 里 类的生命周期 上次写了 30%, 居然丢了 难受, 又要重新写 类的生命周期 加载 使用 卸载 1. 加载 概述 类型的加载 大体流程 装载 连接 验证 准备 解析(可选的) ...

  3. JVM类加载器及Java类的生命周期

    预定义类加载器(三种): 启动(Bootstrap)类加载器: 是用本地代码实现的类装入器,它负责将<Java_Runtime_Home>/lib下面的类库加载到内存中(比如rt.jar) ...

  4. JVM与垃圾回收机制(GC)和类的生命周期

    JVM运行时数据区 GC(垃圾回收机制) 什么是垃圾回收机制: 在系统运行过程中,会产生一些无用的对象,这些对象占据着一定的内存,如果不对这些对象清理回收无用的是对象,可能会导致内存的耗尽,所以垃圾回 ...

  5. <JVM中篇:字节码与类的加载篇>03-类的加载过程(类的生命周期)详解

    笔记来源:尚硅谷JVM全套教程,百万播放,全网巅峰(宋红康详解java虚拟机) 同步更新:https://gitee.com/vectorx/NOTE_JVM https://codechina.cs ...

  6. Java类的生命周期详解

    引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大多只是告 ...

  7. 【转】Java 类的生命周期详解

    一. 引 言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前国内java方面的教材大 ...

  8. 【转载】详解java类的生命周期

    原文地址:http://blog.csdn.net/zhengzhb/article/details/7517213 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑, ...

  9. [Java]类的生命周期(上)类的加载和连接[转]

    本文来自:曹胜欢博客专栏.转载请注明出处:http://blog.csdn.net/csh624366188 类加载器,顾名思义,类加载器(class loader)用来加载 Java 类到 Java ...

随机推荐

  1. 判断字符串的后缀.endswith()

    可以用str.endswith('.jpg')来判断字符串是否以jpg结尾,返回True或者False

  2. 【转载】Ubuntu 12.04 LTS 中文输入法的安装

    原文地址 :  http://www.cnblogs.com/zhj5chengfeng/archive/2013/06/23/3150620.html 我装的是英文版的 Ubuntu12.04,如果 ...

  3. postman学习笔记(一)——最简单的postman入门

    昨天开始正式接触postman的操作,最简单的操作是根据接口文档一个个测试接口. 例如: 测试环境地址:http://111.2.198.4(项目组自己的测试环境,要测试的项目组肯定会给你的) //以 ...

  4. [ZJOI 2007]Hide 捉迷藏

    Description 捉迷藏 Jiajia和Wind是一对恩爱的夫妻,并且他们有很多孩子.某天,Jiajia.Wind和孩子们决定在家里玩捉迷藏游戏.他们的家很大且构造很奇特,由N个屋子和N-1条双 ...

  5. [NOI2016]循环之美

    Description 牛牛是一个热爱算法设计的高中生.在他设计的算法中,常常会使用带小数的数进行计算.牛牛认为,如果在 k  进制下,一个数的小数部分是纯循环的,那么它就是美的.现在,牛牛想知道:对 ...

  6. [HAOI2007]上升序列

    Description 对于一个给定的S={a1,a2,a3,…,an},若有P={ax1,ax2,ax3,…,axm},满足(x1 < x2 < … < xm)且( ax1 < ...

  7. CSAPP-过程调用,数据存储,缓冲区溢出

    程序编译: 1.预处理阶段: 1.文件包含:将#include扩展成文件正文 2.条件编译:根据#if和#ifdef将程序的某部分排除或者包含 3.宏展开:将出现宏引用的地方展开成相应的宏 2.编译阶 ...

  8. [Codeforces]663E Binary Table

    某变换好题.不过听说还有O(2^n*n^2)DP的…… Description 给定一个n*m的01矩阵,你可以选择对任意行和任意列取反,使得最终“1”的数量尽量少. Input 第一行两个整数n,m ...

  9. hdu 5656 CA Loves GCD(n个任选k个的最大公约数和)

    CA Loves GCD  Accepts: 64  Submissions: 535  Time Limit: 6000/3000 MS (Java/Others)  Memory Limit: 2 ...

  10. AtCoder Beginner Contest 071 D - Coloring Dominoes

    Problem Statement We have a board with a 2×N grid. Snuke covered the board with N dominoes without o ...