jvm笔记

好处:

跨平台

内存管理机制,垃圾回收功能

数组下标越界检查

多态

名词解释:

jvm java虚拟机,是java程序的运行环境

jre jvm+基础类库

jdk jre+编译工具

javase jdk+ide工具

javaee javase+应用服务器

jvm的内存结构:

程序计数器:

java源代码-->jvm指令--解释器-->机器码-->cpu

寄存器,记住下一条jvm指令的地址

程序计数器是线程私有的,而且没有内存溢出

虚拟机栈:

每个线程运行所需要的内存,由栈帧组成,一个栈帧就是一次方法的调用,栈帧是每个

方法运行时需要的内存,每个线程只能有一个活动的栈帧,就是正在执行的那个方法

本地方法栈:

一些方法用native修饰表明方法的实现是用C语言或者其他语言实现的,不是用java实现

的。

堆:

通过new关键字创建的对象都会使用堆内存,堆是线程共享的,有垃圾回收机制。

字符串常量池。自java8开始,StringTable在堆里,

方法区:

是堆的一部分,所以方法区是内存共享的。java8后取而代之的是元空间,++运行时常量池++

和++静态常量池++ 存放在元空间里,占用操作系统的内存,++字符串常量池++依然存放在堆里。

字符串常量池用hashTable结构,

栈问题:

1、垃圾回收机制是否会回收栈内存?

不会,垃圾回收是回收堆里面的内存对象。栈内存不需要回收,因为方法结束后栈内存

就自己释放掉了。

2、栈内存分配越大越好吗?

不是,栈内存越大会导致线程数越少

3、方法内的局部变量是否线程安全?

不一定,如果变量没有逃离方法的作用范围,那就是线程安全的,反之就不是线程安全

的(方法参数,方法返回值,局部变量引用了对象),。栈是线程私有的,static变量是

在堆中的就不是线程安全的了。

栈内存溢出的原因:

方法栈帧过多(方法递归)

方法栈帧过大(方法的局部变量太多)
新生代:

老年代:

永久代:使用jvm的堆的内存。java8之后,取消了整个永久代区域,取而代之的是元空间。

元空间:使用操作系统的内存,++运行时常量池++ 和++静态常量池++。

直接内存:操作系统的内存

垃圾回收:

bilibili.com/video/BV1yE411Z7AP P52

相关推荐
阿正呀17 分钟前
Redis怎样实现本地缓存的高效失效通知
jvm·数据库·python
2501_9012005332 分钟前
mysql如何设置InnoDB引擎参数_优化innodb_buffer_pool
jvm·数据库·python
金銀銅鐵1 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
m0_495496412 小时前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
糖炒栗子03262 小时前
【笔记】高分卫星影像 TIF 切片处理
笔记
forEverPlume2 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
Nice_Fold2 小时前
Kubernetes DaemonSet、StatefulSet与Service(自用笔记)
笔记·容器·kubernetes
2301_809204703 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
ZhiqianXia5 小时前
《The Design of Design》阅读笔记
前端·笔记·microsoft
祁白_6 小时前
nmap工具笔记整理
笔记·web安全·测试