- 浏览: 155063 次
- 性别:
- 来自: 湖南
文章分类
最新评论
-
viking_wu:
Android POST方式提交数据 -
hsiunien:
不能正常调用 init android4.3上 是否可以 ...
Android JS双向调用 -
liaokang.java:
Apple.Chen 写道你确定这是插入排序而不是冒泡?插入排 ...
java之插入排序 -
Apple.Chen:
你确定这是插入排序而不是冒泡?
java之插入排序 -
ct19900913:
顶一个!!!
Android ContentProvider共享数据
1.java虚拟机与程序的生命周期
在如下几种情况下,java虚拟机将结束生命周期
a.执行了System.exit()方法
b.程序正常执行结束
c.程序在执行过程中遇到了错误或异常而异常终止
d.由于操作系统错误而导致java虚拟机进程终止
2.java虚拟机工作过程为加载,连接与初始化
加载:查找并加载类的二进制数据到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个Class对象,用来封装类在方法区类的数据结构
连接:将读入带内存的二进制数据合并到虚拟机的运行时环境中
a.验证:确保被加载类的正确性
1>类文件的结构检查
2>语义检查
3>字节码验证
4>二进制兼容性的验证
b.准备:为类的静态变量分配内存,并将其初始化为默认值
c.解析:把类中的符号引用转换为直接引用
初始化:把类中的静态变量赋予正确的初始值
a.假如这个类还没有被加载和连接,那么先加载和连接
b.假如这个类存在直接的父类,并且这个父类没有被初始化,先初始化直接的父类
c.假如类中存在初始化语句,依次执行这些初始化语句
d.当虚拟机初始化一个类时候要求所有父类已经被初始化,但这条规则不使用于接口,在初始化一个类时,并不会先初始化它所实现的接口
e.在初始化一个接口时,并不会先初始化它的父接口,只有当程序首次使用指定接口的静态变量时,才会导致该接口的初始化
3.java程序对类的使用方式可以分为主动使用和被动使用,所有的java虚拟机实现必须在每个类或者接口被java程序首席主动使用时才初始化他们,主动使用有以下几种情况,其它情况均为被动使用
a.创建类的实例
b.访问某个类或者接口的静态变量,或者对静态变量赋值
c.调用类的静态方法
d.反射
e.初始化一个类的子类
f.java虚拟机启动时被标明为启动类的类
4.java提供了两种类型的类加载器
a.java虚拟机自带的加载器
根类加载器(Bootstrap)
扩展类加载器(Extension)
系统类加载器(System)
b.用户自定义的类加载器
java.lang.ClassLoader的子类,用户可以自定义类的加载形式
java虚拟机规范允许类加载器在预料某个类将要被使用时就预先加载它,如果在预先加载的
过程中遇到了.class文件缺失或存在错误,类加载器必须在程序首次主动使用该类时才报告错误,如果这个类一直没有被程序主动使用,那么类加载器不会报告错误
5.类加载器
类加载器用来把类加载到java虚拟机中,从JDK1.2版本开始,类的加载器过程采用父亲委托机制,这种机制能更好保证java平台的安全,在此委托机制中,除了虚拟机自带的根类加载器以外,其余的类加载器都有且只有一个父类加载器
根类加载器:负责加载虚拟机的核心类库,如java.lang.*等,根类加载器的实现依赖于底层操作系统,它并没有继承java.lang.ClassLoader,因为它是用C++所写
扩展类加载器:它的父加载器为根类加载器,他从java.ext.dirs系统属性所指定的目录中加载类库,或者从JDK的安装目录的jre\lib\ext子目录下加载类库,如果用户把自己创建的jar放在该目录下也会由扩展加载器自动加载,它是纯java类,属于java.lang.ClassLoader的子类
系统类加载器:也成为应用加载器,它的父类加载器为扩展加载器,它从环境变量classpath或者系统属性path所指定的目录中加载类,他是用户自定义的类加载器的默认父加载器,它是纯java类,也是java.lang.ClassLoader的子类
每个类加载器都有自己的命名空间,命名空间由该加载器和其所有父类加载器所加载的类组成,在同一个命名空间中不会出现类的完整名字相同的两个类,在不同的命名空间中可以出现,同一个命名空间内的类是相互可见的,子加载器的命名空间包含所有父加载器的命名空间,所有子加载器加载的类能看见父加载器加载的类,但是父加载器不能看见子加载器加载的类
由同一类加载器加载的属于相同包的类组成了运行时包,决定两个类是不是属于同一个运行时包,不仅要看它们的包名是否相同,还要看定义类加载器是否相同,只有属于同一运行时包的类才能互相访问包可见的类和类成员,这样的限制能避免用户自定义的类冒充核心类库去访问核心类库的类和成员
下面是一个自定义加载器的小例子
首先是要被加载的两个类
然后是自定义加载器
在D盘新建对应的目录,当调用testLoader(loader2);时,由于父托管机制,它会先让loader1加载器去加载,而loader1的加载目录在d:\\test\\serverlib\\目录下,将Sample类和Dog类的.class文件放置该目录下,当调用testLoader(loader3);时,由于loader3的父类加载器为根类加载器,它不会对Sample和Dog进行加载,这时候只能由loader3加载器进行加载,而它加载的目录为d:\\test\\otherlib\\,将Sample类和Dog类的.class文件放置该目录下,最后将MyClassLoader.class文件放置在D盘根目录下,通过DOS窗口运行将会看到以下结果
Sample is loaded by:loader1
Dog is loaded by:loader1
Sample is loaded by:loader3
Dog is loaded by:loader3
在如下几种情况下,java虚拟机将结束生命周期
a.执行了System.exit()方法
b.程序正常执行结束
c.程序在执行过程中遇到了错误或异常而异常终止
d.由于操作系统错误而导致java虚拟机进程终止
2.java虚拟机工作过程为加载,连接与初始化
加载:查找并加载类的二进制数据到内存中,将其放在运行时数据区的方法区内,然后在堆区创建一个Class对象,用来封装类在方法区类的数据结构
连接:将读入带内存的二进制数据合并到虚拟机的运行时环境中
a.验证:确保被加载类的正确性
1>类文件的结构检查
2>语义检查
3>字节码验证
4>二进制兼容性的验证
b.准备:为类的静态变量分配内存,并将其初始化为默认值
c.解析:把类中的符号引用转换为直接引用
初始化:把类中的静态变量赋予正确的初始值
a.假如这个类还没有被加载和连接,那么先加载和连接
b.假如这个类存在直接的父类,并且这个父类没有被初始化,先初始化直接的父类
c.假如类中存在初始化语句,依次执行这些初始化语句
d.当虚拟机初始化一个类时候要求所有父类已经被初始化,但这条规则不使用于接口,在初始化一个类时,并不会先初始化它所实现的接口
e.在初始化一个接口时,并不会先初始化它的父接口,只有当程序首次使用指定接口的静态变量时,才会导致该接口的初始化
3.java程序对类的使用方式可以分为主动使用和被动使用,所有的java虚拟机实现必须在每个类或者接口被java程序首席主动使用时才初始化他们,主动使用有以下几种情况,其它情况均为被动使用
a.创建类的实例
b.访问某个类或者接口的静态变量,或者对静态变量赋值
c.调用类的静态方法
d.反射
e.初始化一个类的子类
f.java虚拟机启动时被标明为启动类的类
4.java提供了两种类型的类加载器
a.java虚拟机自带的加载器
根类加载器(Bootstrap)
扩展类加载器(Extension)
系统类加载器(System)
b.用户自定义的类加载器
java.lang.ClassLoader的子类,用户可以自定义类的加载形式
java虚拟机规范允许类加载器在预料某个类将要被使用时就预先加载它,如果在预先加载的
过程中遇到了.class文件缺失或存在错误,类加载器必须在程序首次主动使用该类时才报告错误,如果这个类一直没有被程序主动使用,那么类加载器不会报告错误
5.类加载器
类加载器用来把类加载到java虚拟机中,从JDK1.2版本开始,类的加载器过程采用父亲委托机制,这种机制能更好保证java平台的安全,在此委托机制中,除了虚拟机自带的根类加载器以外,其余的类加载器都有且只有一个父类加载器
根类加载器:负责加载虚拟机的核心类库,如java.lang.*等,根类加载器的实现依赖于底层操作系统,它并没有继承java.lang.ClassLoader,因为它是用C++所写
扩展类加载器:它的父加载器为根类加载器,他从java.ext.dirs系统属性所指定的目录中加载类库,或者从JDK的安装目录的jre\lib\ext子目录下加载类库,如果用户把自己创建的jar放在该目录下也会由扩展加载器自动加载,它是纯java类,属于java.lang.ClassLoader的子类
系统类加载器:也成为应用加载器,它的父类加载器为扩展加载器,它从环境变量classpath或者系统属性path所指定的目录中加载类,他是用户自定义的类加载器的默认父加载器,它是纯java类,也是java.lang.ClassLoader的子类
每个类加载器都有自己的命名空间,命名空间由该加载器和其所有父类加载器所加载的类组成,在同一个命名空间中不会出现类的完整名字相同的两个类,在不同的命名空间中可以出现,同一个命名空间内的类是相互可见的,子加载器的命名空间包含所有父加载器的命名空间,所有子加载器加载的类能看见父加载器加载的类,但是父加载器不能看见子加载器加载的类
由同一类加载器加载的属于相同包的类组成了运行时包,决定两个类是不是属于同一个运行时包,不仅要看它们的包名是否相同,还要看定义类加载器是否相同,只有属于同一运行时包的类才能互相访问包可见的类和类成员,这样的限制能避免用户自定义的类冒充核心类库去访问核心类库的类和成员
下面是一个自定义加载器的小例子
首先是要被加载的两个类
public class Sample { public Sample() { System.out.println("Sample is loaded by:" + this.getClass().getClassLoader()); new Dog(); } }
public class Dog { public Dog(){ System.out.println("Dog is loaded by:" + this.getClass ().getClassLoader()); } }
然后是自定义加载器
import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; public class MyClassLoader extends ClassLoader { private String path = null; private String name = null; private String classType = ".class"; public MyClassLoader(String name) { this.name = name; } public MyClassLoader(ClassLoader classLoader, String name) { super(classLoader); this.name = name; } @Override public String toString() { return this.name; } public String getPath() { return path; } public void setPath(String path) { this.path = path; } public Class<?> findClass(String name) throws ClassNotFoundException { byte[] b = loadClassData(name); return defineClass(name,b,0,b.length); } public byte[] loadClassData(String name) { InputStream is = null; ByteArrayOutputStream baos = null; int ch = 0; byte[] data = null; try { is = new FileInputStream(new File(path+name+classType)); baos = new ByteArrayOutputStream(); while(-1 != (ch=is.read())){ baos.write(ch); } data = baos.toByteArray(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); }finally{ try { is.close(); baos.close(); } catch (IOException e) { e.printStackTrace(); } } return data; } public static void main(String[] args) throws Exception { //定义loader1加载器,默认父加载器为系统加载器,并设置其加载目录 MyClassLoader loader1 = new MyClassLoader("loader1"); loader1.setPath("d:\\test\\serverlib\\"); //定义loader2加载器,指定其父加载器为loader1,并设置其加载目录 MyClassLoader loader2 = new MyClassLoader(loader1,"loader2"); loader2.setPath("d:\\test\\clientlib\\"); //定义loader3加载器,指定其父加载器为根类加载器,并设置其加载目 录 MyClassLoader loader3 = new MyClassLoader(null,"loader3"); loader3.setPath("d:\\test\\otherlib\\"); testLoader(loader2); testLoader(loader3); } public static void testLoader(MyClassLoader loader) throws Exception { //将sample类加载进来,底层会调用findClass Class clazz = loader.loadClass("Sample"); //对类的主动使用 Object object = clazz.newInstance(); } }
在D盘新建对应的目录,当调用testLoader(loader2);时,由于父托管机制,它会先让loader1加载器去加载,而loader1的加载目录在d:\\test\\serverlib\\目录下,将Sample类和Dog类的.class文件放置该目录下,当调用testLoader(loader3);时,由于loader3的父类加载器为根类加载器,它不会对Sample和Dog进行加载,这时候只能由loader3加载器进行加载,而它加载的目录为d:\\test\\otherlib\\,将Sample类和Dog类的.class文件放置该目录下,最后将MyClassLoader.class文件放置在D盘根目录下,通过DOS窗口运行将会看到以下结果
Sample is loaded by:loader1
Dog is loaded by:loader1
Sample is loaded by:loader3
Dog is loaded by:loader3
发表评论
-
java自定义Annotation
2013-08-23 11:41 959自定义Annotation概念篇 来看一个最简单的annota ... -
JBPM安装和配置
2012-09-10 21:30 4504在介绍JBPM的安装之前可能有人会问,JBPM不是说它 ... -
java NIO
2011-09-26 10:25 1338原有的I/O操作都是以字节为单位进行读写的,虽然应用时 ... -
java多线程下载网络资源
2011-09-09 10:43 1437在java中,我们可以通过URL和HttpURLConnect ... -
java方法参数是引用调用还是值调用
2011-08-19 14:17 1007方法调用(call by) 是一个标准的计算机科学术语 ... -
HashSet介绍
2011-08-18 21:35 936(1) 为啥要用HahSet? 假如我们现在想要在一大 ... -
java日期转化"BUG"
2011-08-05 16:43 1010最近看了一个有意思的帖子,拿来分享一下 SimpleDa ... -
java之网络编程
2011-08-03 11:12 1036提到java的网络编程,大家肯定会想到TCP,UDP协议,下面 ... -
HashMap底层的实现
2011-06-20 13:20 7432首先我们来看看HashMap的底层源码 /** ... -
java动态代理分析
2011-06-07 12:48 9071.所谓动态代理类是这样一种class,首先它是在运行期生成的 ... -
TreeSet分析
2011-06-04 21:08 10271. |——SortedSet接口——TreeSe ... -
equals和hashCode方法分析
2011-06-04 17:51 9421.HashSet存放的是无序,不能重复的对象,当添加一个对象 ... -
ArrayList与LinkedList分析
2011-06-04 11:49 995先看看ArrayList源码 public class A ... -
HashMap和Hashtable分析
2011-05-26 22:17 10061.先说继承关系吧 Java代码 public class H ... -
java的克隆
2011-05-08 22:02 1022所谓复制就是将一份东西拷贝一份,在java中有浅复制和深复制的 ... -
java线程通信
2011-05-08 16:39 784一说到线程通信我们就会想到生产者和消费者,哲学家就餐问题,下面 ... -
java多线程及synchronized
2011-05-08 13:31 635通常我们所说的程序它只是一个静态的概念,而进程是其动态性的体现 ... -
java反射机制2
2011-05-06 08:55 903package com.lamp.test; pub ... -
java反射机制
2011-05-05 19:47 1007反射是java一大特征,没有它java体现不出它那些优点,更别 ... -
JPA及联合主键的使用
2011-04-26 20:07 1600JPA全称为java persistence AP ...
相关推荐
### Java虚拟机基础知识 #### 1. Java虚拟机(JVM)的概念 Java虚拟机(JVM)是一种假想的计算机,它为运行Java字节码提供了一个运行环境。JVM的主要功能是解释并执行由Java编译器产生的字节码文件(.class文件)。...
#### 一、Java虚拟机基础知识 1. **Java虚拟机(JVM)概述** - Java是一种面向对象的编程语言,具有“一次编写,到处运行”的特点。 - Java代码通过编译器转换为字节码,由Java虚拟机执行。 - JVM对编译后的Java...
总之,《Java虚拟机规范(Java SE 7版)》是Java开发者的重要参考资料,它帮助我们理解JVM如何工作,如何与Java语言的其他部分交互,以及如何利用这些知识来提升应用的效率和可靠性。通过学习这份规范,开发者能够更...
Java虚拟机(JVM)是Java编程语言...本PPT作为Java虚拟机基础的学习资料,将帮助读者深入理解JVM的内部运作,提升Java开发技能。通过阅读和学习,你将能够更好地调试和优化Java程序,实现更高效的资源管理和运行效率。
中文版的《Java虚拟机规范》填补了国内关于JVM领域知识的空白,使得中国广大对JVM感兴趣的程序员能够克服语言障碍,深入学习和掌握这一关键技术。译者们在翻译过程中,注重保持作品的准确性与可读性,尽可能采用通俗...
在Java虚拟机第二版中,我们可以深入探讨以下几个关键知识点: 1. **字节码与类加载机制**:Java程序编译后生成的是.class文件,里面包含的是字节码。JVM通过类加载器将这些字节码加载到内存中,进行验证、准备、...
1. **Java虚拟机基础**:首先,书本会介绍Java虚拟机的基本概念,包括其设计目标、架构和工作原理。这包括类加载机制、字节码解析、垃圾回收机制等。了解这些基础知识是理解任何Java虚拟机实现的基础。 2. **嵌入式...
总的来说,掌握Java虚拟机不仅有助于编写更高效的代码,也是解决运行时问题和优化性能的基础。通过深入学习JVM,Java程序员能够更好地理解程序的运行机制,从而编写出更健壮、性能更优的软件。这份PDF教程将是你深入...
根据上述内容,以下是关于Java虚拟机规范的详细知识点: 1. Java虚拟机(JVM)的概念:JVM是Java程序的运行时环境,它负责将Java字节码转换为特定平台上的机器码执行。它隔离了Java程序和底层操作系统,使得Java...
Java基础知识学习:包括JVM虚拟机、对象模型等Java基础知识代码案例Java基础知识学习:包括JVM虚拟机、对象模型等Java基础知识代码案例Java基础知识学习:包括JVM虚拟机、对象模型等Java基础知识代码案例Java基础...
7. **性能考量**:虽然虚拟机规范本身并不直接涉及性能优化,但在实际应用中,理解这些基础知识对于提高程序效率非常有帮助。 #### 五、翻译过程和技术背景 译者们在翻译过程中面临了诸多挑战,例如专业术语的准确...
### Java虚拟机规范SE8知识点概述 #### 一、引言 - **历史背景**:Java虚拟机(JVM)自1995年首次发布以来,已经发展成为支持多种编程语言的重要平台。 - **Java虚拟机定义**:Java虚拟机(JVM)是一种能够执行Java...
Java虚拟机(JVM)是Java程序运行的核心,它负责解释和执行字节码,为开发者提供了跨平台的运行环境。深入理解JVM对于优化代码性能、排查问题以及提升编程能力至关重要。本篇文章将详细探讨JVM的工作原理、内存管理...
由于无法查看实际的图片和OCR扫描文字内容,我将基于标题和描述提供关于Java虚拟机(JVM)规范的详细知识点。 ### Java虚拟机规范知识点 #### 1. JVM概述 Java虚拟机是运行所有Java程序的抽象计算机,它遵循一定的...
不过,根据文件标题和描述信息,可以提供关于“Java虚拟机规范”的知识点。 《Java虚拟机规范》是Java技术的核心文档之一,它详细描述了Java虚拟机(JVM)的行为,包括其内部结构、数据类型、执行模型、指令集、...
### 深入Java虚拟机知识点总结 #### 第一章 Java体系结构介绍 - **Java体系结构概述**:本章主要介绍了Java体系结构的基本概念及其组成部分。Java体系结构旨在为开发者提供一个统一、高效且跨平台的应用开发环境。...