1.jvm的位置

java使用Kabeja解析DWG java chm解析_java使用Kabeja解析DWG

2.JVM的体系结构

2.1java运行时候的步骤

首先.java文件经过javac编译成classFile文件,在经过类加载器(class Loader),类加载器把文件装载到jvm里面,jvm还要与类加载器进行互动。jvm加载器称之为运行时数据区。Runtime发生异常一般就在这个区域发生,一般是捕获不到的运行是异常。

java使用Kabeja解析DWG java chm解析_java_02


栈是用完就弹出啦,栈里面肯定是不能存在垃圾的。栈本地方法和程序计数是100%不会有垃圾的。

jvm调优99%调的是方法区和堆,主要调的是堆

3.类装载器

作用:加载Class文件-->new Student();

java使用Kabeja解析DWG java chm解析_maven_03

public class Car {

    public static void main(String[] args) {

        //new 出来的 实例对象
        Car car1 = new Car();
        Car car2 = new Car();
        Car car3 = new Car();

        //打印出hashCode   new出来之后3个对象的hashCode是不一样的
        System.out.println(car1.hashCode());
        System.out.println(car2.hashCode());
        System.out.println(car3.hashCode());

        //getClass获取Car的类
        Class<? extends Car> aClass1 = car1.getClass();
        Class<? extends Car> aClass2 = car2.getClass();
        Class<? extends Car> aClass3 = car3.getClass();

        //他们对象getClass的模板是同一个  同一个模板
        System.out.println(aClass1.hashCode());
        System.out.println(aClass2.hashCode());
        System.out.println(aClass3.hashCode()); 	
	}
}

类加载机制他是层层往上走的。
AppClassLoader(应用程序类加载器)–>ExtClassLoader(扩展类加载器)–>boot(根加载器)rt.jar
一层一层往上找。java里面有个安全机制:双亲委派机制
运行一个类他会向上找,先找应用程序的加载器,再去找扩展类里面的加载器,再找根加载器中的类,最终会执行类加载器中的代码。
例如:我们在java类中自定义个一个java lang String 写一个main方法,我们运行的时候他就会报找不到当前main方法。因为他执行的是根加载器中的java lang String中的方法,rt.jar中的string里面是没有main方法的。这就是双亲委派安全机制。
双亲委派机制就是app加载器会向上委派两次所以叫双亲委派。

4. Native(JNI)

凡是带了native关键字的,说明java的作用范围达不到了,就会去调用c语言的库。会调用本地方法栈。调用本地方法的接口JNI

JNI的作用:扩展java的使用,融合不同语言为java所用! 最初是想融合C和C++

java诞生的时候C C++横行,想要立足必须调用C C++的程序,他在内存区专门开辟了一块标记区域:native method Stack 方法,在最终执行的时候,加载本地方法库中的方法通过JNI.

后期调用的话目前一般用 Socket ,webSocket 和http等

java使用Kabeja解析DWG java chm解析_java_04

4.1 PC寄存器

程序计数器:每一个线程都有一个程序计数器,是线程私有的就是一个指针,指向方法区的方法字节码。他是一个非常小的内存空间,几乎可以忽略不计。