java中gc的认识,java JVM GC 笔记(个人对GC 或JVM 的了解)

JVM 是在操作系统上的一个平台,与操作系统间有个装换器,将字节码文件转换成对应平台的机器码,字节码文件从编译器编译.java文件产生。

JVM的结构 栈(存放的就是方法的引用,局部变量,方法体)、堆(常量,方法的实例)、方法区(常量池、静态方法区)、程序计数器、本地方方法栈(不受虚拟机限制的本地方法栈区)

有一张图挺详细的

f55d4a3f8e54c47a60337216cd6be003.png

https://blog.csdn.net/Marvel__Dead/article/details/69220153?locationNum=5&fps=1

用户编写的java文件通过jvm的类加载器加载进内存

编译优化的技术

方法内联,去除方法调用成本,

冗余访问消除

复写传播

无用代码消除

公共子表达式消除,没必要重复计算公共子表达式的值

数组边界检查消除

逃逸分析,分析对象的动态作用域,一个对象定以后,被外部方法调用,称为方法逃逸,被其他线程访问到,称为线程逃逸 栈上分配 同步消除 标量替换

类加载器:

bootstrap(根类加载器)加载JVM自身类

extension(扩展类加载器)加载lib下的jar包

system(系统类加载器)加载用户编写的java文件

JVM加载类是按需加载 使用双亲委派模式

双亲委派模式:

当某个类加载器收到类加载的请求时不会自己直接加载 而是先去找父类加载器 当父类加载器还有父类时一直向上请求 直到根节点根类加载器;然后向下返回 当父类加载器能加载时 成功返回,不能加载就交由子类尝试加载

类加载机制 : 加载 验证 准备 解析 初始化 运行 狗带

GC

JVMGC

GC主要发生在堆内存中 现在采用为分代回收

判断对象是否是要回收的对象有可达性分析 和引用计数等

引用计数:新增一个引用计数+1 引用被释放计数-1当计数为0则代表对象可回收 (此方法过时)

可达性分析:从GC Root开始 当一个对象和GC Root没有间接或者直接的引用链时(么有直接或者间接的引用关系) 该对象不可用

GC Root包括:1、虚拟机栈中引用的对象。2、方法区中类静态属性实体引用的对象。3、方法区中常量引用的对象。4、 本地方法栈中JNI引用的对象。

分代回收:JVM中分为3个大区 年轻代 老年代 永久代(堆外内存)而大区中又有小区 所有的新生对象都是放在年轻代中 当区块中满了时会将还存存活的对象(没有被GC掉的)移到下个区块

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值