JVM系列-Java内存区域

本文详细解析了Java虚拟机在运行时如何划分内存区域,包括程序计数器、Java虚拟机栈、本地方法栈、Java堆和方法区等功能区域及其工作原理。

个人博客导航页(点击右侧链接即可打开个人博客):大牛带你入门技术栈 

运行时数据区域

     Java虚拟机在Java程序执行过程中会把它所管理的内存划分为若干个数据区域,有的区域随着虚拟机进程的启动而存在,有的区域依赖用户线程的启动和结束而建立和销毁。

RUNTIME DATA AREAS SHARED AMONG ALL THEADS:由所有线程共享的数据区

THREAD  SPECIFIC RUNTIME DATA AREAS:线程隔离的数据区

a,程序计数器(PROGRAM COUNTER REGISTER):是一块较小的内存空间,他的作用可以看做事当前线程所执行的字节码的行号指示器。字节码解释器工作时就是通过改变这个计数器的值来选 取下一条需要执行的字节码指令,分支,循环,跳转,异常处理,线程回复等基础功能都需要依赖这个程序计数器来完成。各个线程间的计数器互不影响,独立存 储。

b,Java虚拟机栈(JAVA STACK):也是线程私有的,每个方法被执行的时候都会同时创建一个栈帧用于存储局部变量表,操作栈,动态链接,方法出口灯信息。每个方法被调用直至执 行完成的过程,就对应着一个栈帧在虚拟机栈中从入栈到出栈的过程。在java虚拟机规范中,对这个区域规定了两种异常状况:如果线程请求的栈深度大于虚拟 机所允许的深度,将会抛出StackOverflowError异常;如果虚拟机栈扩展时无法申请到足够的内存时会抛出OutOfMemoryError 异常。

c,本地方法栈(NATIVE METHOD STACK):和虚拟机栈发挥的作用相似,区别不过是虚拟机站为虚拟机执行java方法服务,而本地方法栈则是为虚拟机使用到的Native方法服务。

d,Java堆(HEAP):java虚拟机中所广泛利用的内存中最大的一块,被所有线程共享的一块内存区域,在虚拟机启动时创建。此内存区域用于存放 对象实例。现在收集器基本上都是采用分代收集算法,分为:新生代和年老代;在细致一点有Eden空间,From Survivor空间,To Survivor空间等。

e,方法区(METHOD AREA):各个线程共享的存储区域,用于存储已被虚拟机加载的类信息,常量,静态方法,即时编译器编译后的代码等数据。也就是所说的永久代(Permanent Generation)。

f,运行时常量池:Java虚拟机没有做任何细节的要求,不同的提供商实现的虚拟机可以按照自己的需要来实现这个内存区域。一般来说,除了保存Class文件中描述的符号引用外,还会把翻译出来的直接引用也存储在运行时常量池中。

附Java/C/C++/机器学习/算法与数据结构/前端/安卓/Python/程序员必读/书籍书单大全:

(点击右侧 即可打开个人博客内有干货):技术干货小栈
=====>>①【Java大牛带你入门到进阶之路】<<====
=====>>②【算法数据结构+acm大牛带你入门到进阶之路】<<===
=====>>③【数据库大牛带你入门到进阶之路】<<=====
=====>>④【Web前端大牛带你入门到进阶之路】<<====
=====>>⑤【机器学习和python大牛带你入门到进阶之路】<<====
=====>>⑥【架构师大牛带你入门到进阶之路】<<=====
=====>>⑦【C++大牛带你入门到进阶之路】<<====
=====>>⑧【ios大牛带你入门到进阶之路】<<====
=====>>⑨【Web安全大牛带你入门到进阶之路】<<=====
=====>>⑩【Linux和操作系统大牛带你入门到进阶之路】<<=====

天下没有不劳而获的果实,望各位年轻的朋友,想学技术的朋友,在决心扎入技术道路的路上披荆斩棘,把书弄懂了,再去敲代码,把原理弄懂了,再去实践,将会带给你的人生,你的工作,你的未来一个美梦。

内容概要:本文详细介绍了“秒杀商城”微服务架构的设计与实战全过程,涵盖系统从需求分析、服务拆分、技术选型到核心功能开发、分布式事务处理、容器化部署及监控链路追踪的完整流程。重点解决了高并发场景下的超卖问题,采用Redis预减库存、消息队列削峰、数据库乐观锁等手段保障数据一致性,并通过Nacos实现服务注册发现与配置管理,利用Seata处理跨服务分布式事务,结合RabbitMQ实现异步下单,提升系统吞吐能力。同时,项目支持Docker Compose快速部署和Kubernetes生产级编排,集成Sleuth+Zipkin链路追踪与Prometheus+Grafana监控体系,构建可观测性强的微服务系统。; 适合人群:具备Java基础和Spring Boot开发经验,熟悉微服务基本概念的中高级研发人员,尤其是希望深入理解高并发系统设计、分布式事务、服务治理等核心技术的开发者;适合工作2-5年、有志于转型微服务或提升架构能力的工程师; 使用场景及目标:①学习如何基于Spring Cloud Alibaba构建完整的微服务项目;②掌握秒杀场景下高并发、超卖控制、异步化、削峰填谷等关键技术方案;③实践分布式事务(Seata)、服务熔断降级、链路追踪、统一配置中心等企业级中间件的应用;④完成从本地开发到容器化部署的全流程落地; 阅读建议:建议按照文档提供的七个阶段循序渐进地动手实践,重点关注秒杀流程设计、服务间通信机制、分布式事务实现和系统性能优化部分,结合代码调试与监控工具深入理解各组件协作原理,真正掌握高并发微服务系统的构建能力。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值