网易云-学习笔记-高性能编程 JAVA程序运行原理分析

227 阅读2分钟

.class文件内容

  1. class文件包括JAVA程序执行的字节码
  2. 数据严格按照格式紧凑排列在class文件中的二进制流
  3. 中间无任何分隔符
  4. 文件开头有一个0xcafebabe(16进制)特殊的一个标志

JVM运行时数据区

  1. 线程共享部分:方法区,堆内存
  2. 线程独占部分:虚拟机栈,本地方法栈,程序计数器

​​​​线程独占:每个线程都会有她独立的空间,随线程生命周期而创建和销毁

线程共享:所有线程都能访问这块内存数据,随虚拟机或者GC而创建和销毁

方法区:JVM用来存储加载的类信息,常量,静态变量,编译后的代码等数据,虚拟机规范中这是一个逻辑区划。具体根据不同的虚拟机来实现。如:oracle中的HotSport在Java1.7中方法区存放在永久代,Java1.8中放在元数据空间,并且通过GC管理机制对这个区域进行管理。

**堆内存:**存放对象的区域,堆内存还可以分为老年代,新生代(Eden,From Survivor ,To Survivor),JVM启动时创建,存放对象的实例。垃圾回收器主要就是管理内存。如果满了,就会出现OutOfMemoryError

**虚拟机栈:**每个线程都在这个空间有一个私有空间。线程栈由多个栈帧(Stack Frame)组成。栈帧内容包含:局部变量表,操作数栈,动态链接,方法返回地址,附加信息等。栈内存弄人最大内存是1M,超出则抛出StackOverflowError

**本地方法栈:**和虚拟机栈功能类似,虚拟机栈是为虚拟机执行JAVA方法而准备的,本地方法栈是为虚拟机使用Native本地方法而准备的。虚拟机规范没有规定具体的实现,由不通的虚拟机厂商去实现。HotSpot虚拟机中虚拟机栈和本地方法栈的实现方式一样的。同样,超出大小以后,会抛出StackOverflowError

**程序计数器:**Program Counter Register 记录当前线程执行字节码的位置,存储的是字节码指令地址,如果执行Native方法,则计数器值为空。每一个线程都在这个空间有一个私有的空间,占用内存空间很少。CPU同一时间,只会执行一条线程中的指令。JVM多线程会轮流切换并分配CPU执行时间的方式。为了线程切换后,需要通过程序计数器,来恢复正确的执行位置。