1.jvm的位置
2.JVM的体系结构
2.1java运行时候的步骤
首先.java文件经过javac编译成classFile文件,在经过类加载器(class Loader),类加载器把文件装载到jvm里面,jvm还要与类加载器进行互动。jvm加载器称之为运行时数据区。Runtime发生异常一般就在这个区域发生,一般是捕获不到的运行是异常。
栈是用完就弹出啦,栈里面肯定是不能存在垃圾的。栈本地方法和程序计数是100%不会有垃圾的。
jvm调优99%调的是方法区和堆,主要调的是堆
3.类装载器
作用:加载Class文件-->new Student();
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等
4.1 PC寄存器
程序计数器:每一个线程都有一个程序计数器,是线程私有的就是一个指针,指向方法区的方法字节码。他是一个非常小的内存空间,几乎可以忽略不计。