学习笔记 1.高性能编程1.1.1 JAVA程序运行原理分析

.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执行时间的方式。为了线程切换后,需要通过程序计数器,来恢复正确的执行位置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值