JVM线程引擎和内存共享区的交互及程序计数器

多线程的Java应用程序:

线程:

从面向对象(OOP)的角度而言,相当于一个对象,该对象中具有执行代码,同时也有要处理的数据,数据包含Thread工作时要访问的数据,同时也包含线程的Stack。在Stack中,包含Thread本地的数据,也包含了拷贝的全局数据。

从面向过程的角度而言,线程 = 代码 + 数据。

Main Memory:全局共享内存空间


程序计数器(Program Counter Register)

为了让线程正常工作就提出了程序计数器,每个线程都有自己的程序计数器,这样当线程执行切换的时候就可以在上次执行的基础继续执行,仅仅从一条线程线性执行的角度而言,代码是一条一条的往下执行的,JVM就是通过读取程序计数器的值,来决定该线程下一条需要执行的字节码指令,进而进行选择语句、循环、异常处理等。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值