【从零开始学习JVM】程序计数器


🌈 个人主页: Hygge_Code
🔥 热门专栏:从0开始学习Java | Linux学习 | 计算机网络
💫 个人格言: "既然选择了远方,便不顾风雨兼程"

文章目录

程序计数器

  • 为什么需要程序计数器:Java 支持多线程并发运行,CPU 调度器会为每个线程分配时间片。如果线程 1 在时间片内没有执行完,就需要保存当前执行状态,切换到线程 2;等下次切换回来时,要能接着上次的位置继续执行。

     线程切换后,要知道"下一条指令该从哪儿执行",就需要依靠程序计数器

     由于每个线程执行指令的位置互不干扰,因此每个线程都有独立的程序计数器

  • 程序计数器的具体作用:程序计数器是一块较小的内存空间,可以看作当前线程所执行字节码的行号指示器

     字节码解释器通过改变计数器的值来选取下一条需要执行的字节码指令。分支、循环、跳转、异常处理、线程恢复等功能,都依赖这个计数器完成。

    主要两个作用:

    • 字节码解释器通过程序计数器依次读取指令,实现代码的流程控制(顺序、选择、循环、异常处理等)。
    • 多线程环境下,记录当前线程执行位置,线程切回后能从上次中断处继续执行。
  • 程序计数器的生命周期与线程完全同步

    • 创建:随着线程的创建而创建
    • 销毁:随着线程的销毁而销毁
  • 补充

    • 线程执行 Java 方法 (非native方法)时,程序计数器记录的是当前 JVM 字节码指令的地址
    • 线程执行 native 本地方法 时,计数器值为 Undefined(未定义)。因为 native 方法不基于 JVM 字节码执行,而是通过 JNI 调用底层系统代码,JVM 无需记录字节码地址。

⚠️注意:程序计数器是 JVM 规范中唯一一个不会发生 OutOfMemoryError 的内存区域。因为它只存一个地址,占用内存极小且固定,不会出现内存溢出。


如果我的内容对你有帮助,请 点赞 , 评论 , 收藏 。创作不易,大家的支持就是我坚持下去的动力!

相关推荐
葫芦和十三2 小时前
图解 MongoDB 14|Cache 与淘汰:WiredTiger 的内存治理
后端·mongodb·面试
人活一口气7 小时前
Spring Boot与AIGC的完美结合:从零搭建智能内容生成平台
java·spring boot·aigc
像我这样帅的人丶你还9 小时前
Java 后端详解(三):全局异常处理与 JPA 数据库映射
java·后端
NE_STOP9 小时前
vibe Coding -- 小项目实战
java
PBitW9 小时前
GPT训练我的第二天,我表示不过如此!!!😕😕😕
前端·javascript·面试
kyriewen10 小时前
白宫直接给 OpenAI 下了限制令,GPT-5.6 不能随便放出来了
前端·javascript·面试
未秃头的程序猿15 小时前
Java 26正式发布!这3个新特性,让代码量直接减半
java·后端·面试
用户2986985301415 小时前
Word 文档文本查找与替换的 Java 实现方案
java·后端
阿哉15 小时前
Nacos 服务发现源码:藏在背后的两套事件机制,90%的人只讲了一半
java
咖啡八杯15 小时前
GoF设计模式——命令模式
java·设计模式·架构