java在多线程环境下,为什么要为每个线程维护一个独立的程序计数器

java在多线程环境下,为什么要为每个线程维护一个独立的程序计数器,第1张

程序计数器指向纤拦渗下一条指令(存储下一条CPU指令的地址),线程是CPU的执行和调度单元,不同的线程的执行路径(执行的指令)、和执毁脊行时序不一样,所以衡枯每个线程有自己私有的程序计数器和堆栈。

大家在进行程序系统维护的时候是否因为java编程的内存管理问题而无法快速解决导致系统出错呢?下面我们就一起来了解和学习一下,关于java编程内存管理都有哪些知识点。

程序计数器(了解)程序计数器,可以看做是当前线程所执行的字节码的行号指示器。

虚拟机的概念模型里,字节码解释器工作就是袭培乎通过改变程序计数器的值来选择下一条需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能都要依赖这个计数器来完成。

Java虚拟机栈(了解)Java虚拟机栈也是线程私有的,它的生命周期与线程相同。

虚拟机栈描述的是Java方法执行的内存模型:每个方法在执行的同时都会创建一个栈帧用于存储局部变量表、 *** 作数栈、动态链表、方法出口信息等。

每一个方法从调用直至执行完成的过程,就对应着一个栈帧在虚拟机栈中入栈到出栈的过程。

局部变量表中存放了编译器可知的各种基本数据类型(boolean、byte、char、short、int、float、long、double)、对象引用和returnAddress类型(指向了一条字节码指令的地址)。

如果扩展时无法申请到足够的内存,就会抛出OutOfMemoryError异常。

本地方法栈(了解)本地方法栈与虚拟机的作用相似,不同之处在于虚拟机栈为虚拟机执行的Java方法服务,而本地方法栈则为虚拟机使用到的Native方法服务。

有的虚拟机直接把本地方法栈和虚拟机栈合二为一。

会抛出stackOverflowError和OutOfMemoryError异常。

Java堆堆内存用来存放由new创建的对象实例和数组。

(重点)Java堆是拍悉所有线程共享的一块内存区域,在虚拟机启动时创建,此内存区域的目的就是存放对象实例。

Java堆是垃圾收集器管理的主要区域。

java课程培训机构http://www.kmbdqn.cn/发现由于现在收集器基本采用分代回收算法,所以Java堆还可细分为:新生代和老年代。

从内存分配的角中渣度来看,线程共享的Java堆中可能划分出多个线程私有的分配缓冲区(TLAB)。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12560891.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存