虚拟机加载类机制

加载--连接(验证、准备、解析)---初始化----使用---卸载

当且仅当5中情况 "初始化": 比如new关键字、反射、初始化一个类时父类未初始化,则初始化父类、main方法的类,JDK1.7时 methodHandle方法。

加载:
       加载做了三件事:

1、通过一个类的全限定名来获取定义此类的二进制字节流

2、讲这个字节流所代表的静态存储结构转化为方法区的运行时数据结构

3、在内存中生成一个代表着各类的java.lang.Class对象,作为方法区的这个类的各种数据的访问入口

验证:

文件格式验证、元数据验证、字节码验证、符号引用验证

准备:

  正式为类变量分配内存并设置变量初始值。这些变量使用的内存都将在方法区中进行分配
   public static int value = 123;
        类变量指静态变量,准备阶段会给value设置 0 ,赋值为123是在初始化阶段才会执行

 解析:

解析阶段是虚拟机将常量池内的符号引用替换为直接引用的过程 

初始化:

真正执行JAVA代码,,,<clinit>()方法由编译器 自动收集类中所有类变量的赋值动作和静态语句块(static{})语句合并产生 .收集顺序由出现顺序决定。

 

原文地址:https://www.cnblogs.com/zhimingxin/p/8961575.html

时间: 2024-10-14 18:06:50

虚拟机加载类机制的相关文章

JVM加载类的过程,双亲委派机制中的方法

JVM加载类的过程: 1)JVM中类的整个生命周期: 加载=>验证=>准备=>解析=>初始化=>使用=>卸载  1.1.加载 类的加载阶段,主要是获取定义此类的二进制字节流,并将这个字节流所代表的静态存储结构转化为方法区的运行时数据结构,最后在Java堆中生成一个代表这个类的java.lang.Class对象作为方法区这些数据的访问入口.相对于类加载过程的其他阶段,加载阶段是开发期可控性最强的阶段.我们可以通过定制不通的类加载器,也就是ClassLoader来控制二进制

虚拟机(JVM)如何加载类

首先JVM加载类的一般流程分三步: 加载 链接 初始化 那么是否全部Java类都是这样三步走的方式加载呢?我们可以从Java的数据类型去出发.Java分基本类型和引用类型.其中按照面向对象的特性,一切皆对象,那么对于基本类型也应该是对象.但是为了在执行效率和内存占用上进行调优,Java将基本类型特殊处理.所以Java基本类型加载都是Java虚拟机预先定义好了,所以没有加载这个步骤了.引用类型就是类,接口,数组.其中数组是直接由虚拟机直接生成的.类和接口是字节流,都是需要加载. 正文 Java基本

虚拟机加载机制读后感

周末花了两个小时左右阅读了一下,深入理解Java虚拟机第七章有关虚拟机加载的相关知识,主要要点记录如下. 1,java虚拟机加载的过程(狭义的理解就是虚拟机将class文件加载到内存的方法区的过程)主要经历: 加载=>验证=>准备=>解析=>初始化=>使用=>卸载 2,其中初始化过程与我们平时写的应用关系最大.虚拟机规定了有且仅有一下五中条件,才会对类进行初始化. a, new对象以及对类的静态变脸进行读写 b, 初始化子类之前需要初始化父类 c, 程序启动时main函

Android Handler 异步消息处理机制的妙用 创建强大的图片加载类

转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/38476887 ,本文出自[张鸿洋的博客] 最近创建了一个群,方便大家交流,群号:55032675 上一篇博客介绍了Android异步消息处理机制,如果你还不了解,可以看:Android 异步消息处理机制 让你深入理解 Looper.Handler.Message三者关系 .那篇博客的最后,提出可以把异步消息处理机制不仅仅是在MainActivity中更新UI,可以用到别的地方,

java 反射机制与动态加载类学习要点

获取Class类的对象: 假设Foo是一个类,Foo foo = new Foo():则 第一种:Class c1 = Foo.class; 第二种:Class c2 = foo.getClass(); 第三种:Class c3 = Class.forName("com.nudt.reflection.Foo"); //会抛出异常 此时  c1 == c2 == c3 为true 也可以通过c1\c2\c3创建Foo的实例: Foo foo = (Foo)c1.newInstance(

Android运行时ART加载类和方法的过程分析

在前一篇文章中,我们通过分析OAT文件的加载过程,认识了OAT文件的格式,其中包含了原始的DEX文件.既然ART运行时执行的都是翻译DEX字节码后得到的本地机器指令了,为什么还需要在OAT文件中包含DEX文件,并且将它加载到内存去呢?这是因为ART运行时提供了Java虚拟机接口,而要实现Java虚拟机接口不得不依赖于DEX文件.本文就通过分析ART运行时加载类及其方法的过程来理解DEX文件的作用. 老罗的新浪微博:http://weibo.com/shengyangluo,欢迎关注! 在前面An

自动加载类PHP中spl_autoload_register函数的用法

spl_autoload_register(PHP 5 >= 5.1.2) spl_autoload_register — 注册__autoload()函数 说明bool spl_autoload_register ([ callback $autoload_function ] )将函数注册到SPL __autoload函数栈中.如果该栈中的函数尚未激活,则激活它们. 如果在你的程序中已经实现了__autoload函数,它必须显式注册到__autoload栈中.因为 spl_autoload_

php 自动加载函数、自动加载方法、自动加载类

在PHP开发过程中,如果希望从 外部引入一个class,通常会使用include和require方法,去把定义这个class的文件包含进来.这个在小规模开发的时候,没什么大问 题.但在大型的开发项目中,这么做会产生大量的require或者include方法调用,这样不因降低效率,而且使得代码难以维护,况且 require_once的代价很大. 在PHP5之前,各个PHP框架如果要实现类的自动加载,一般都是按照某种约定自己实现一个遍历 目录,自动加载所有符合约定规则的文件的类或函数. 当然,PHP

框架开发(五)----自动加载类

一 . 为什么自动加载 自动加载字面的意思就不解释了.我这里自动加载类解析下 是自动加载类文件的意思.__autoload方法完全可行,但是不要问为什么,还是用spl_autoload_register.不只是灵活,而且就是灵活,还是灵活,体现在__autoload只能这么命名,spl_auto_register() 能调用不同的函数. 二  自动加载函数原理   通常情况下,一个类的定义都是一个文件,当类与类需要相互引用的时候,就需要include(require)相应的类文件,带来的问题就是