jvm(1)

jvm:一个运行在os上的微型os
jvm机构图:
堆外内存
运行时数据区:线程共享区:堆:
方法区:运行时常量池:
私有线程区:程序计数器
本地方法区
虚拟机栈:栈帧:操作数栈
局部变量表

运行时jvm的动作:
1jvm向os申请内存
2jvm初始化数据区
3类加载到方法区
4执行方法,创建对象
5最后堆中的对象被回收

堆:新生代:eden from to
老年代:Tenured

栈帧之间的数据共享:一般情况下,俩个栈帧之间是独立的,但是如果俩个方法之间存在着调用,那么这俩个栈帧之间会有一个数据共享区,既“让下面栈帧的操作数栈和上面栈帧的部分局部变量重叠在一起。这样做不但节约了一部分空间,更加重要的是在进行方法调用时就可以直接公用一部分数据,无需进行额外的参数复制传递了。”

内存溢出 oom(out of memory)
栈溢出:一个线程1m,一致创建线程大于本机剩余内存
堆溢出:设置大小后一致创建对象
方法区溢出:一致加载类,用cglib
本机直接内存溢出:常见超大字符串,一般为 Integer.maxValue

常量池:
class常量池 类 字面量 符号引用
运行时常量池:直接引用
字符串常量池

字符串常量池:

posted @   小傻孩丶儿  阅读(126)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示