博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入理解Java虚拟机(三)、垃圾收集算法
阅读量:6005 次
发布时间:2019-06-20

本文共 466 字,大约阅读时间需要 1 分钟。

1、第一门真正使用内存动态分配和垃圾收集技术的语言:Lisp

2、程序计数器、虚拟机栈、本地方法栈这3个区域随线程而生灭,这几个区域的内存会随着方法结束或线程结束而回收,GC关注的是Java堆和方法区

3、引用计数法很难解决对象之间相互循环引用的问题

4、在主流商用程序语言的主流实现中,都是通过可达性分析而不是引用计数来判定对象是否存活的。

可达性分析原理:通过一系列称为GC Roots的对象作为起点,从这些节点开始向下搜索,搜索所走过的路径称为引用链,当一个对象到GC Roots没有任何引用链相连时,证明此对象是不可用的。

可以作为GC Roots的对象包括以下几种:

a、虚拟机栈(栈帧中的本地变量表)中引用的对象

b、方法区中类静态属性引用的对象

c、方法区中常亮引用的对象

d、本地方法栈中JNI(即一般说的Native方法)引用的对象

 

 

5、JDK1.2之后,将引用分为强引用、软引用、弱引用、虚引用4种

详见

 

6、 

 

转载于:https://www.cnblogs.com/boucher/p/5971096.html

你可能感兴趣的文章
纯css实现左右横线,文字自适应居中效果
查看>>
唯品会HDFS性能挑战和优化实践
查看>>
JavaScript 设计模式
查看>>
Java EE供应商和伦敦Java用户组宣布新的MicroProfile
查看>>
PostgreSQL中的大容量空间探索时间序列数据存储
查看>>
敏捷制造:并不是你想像的矛盾体
查看>>
jQuery选择器和事件
查看>>
十、syslog日志与loganalyzer日志管理
查看>>
Python多进程并发写入PostgreSQL数据表
查看>>
mysql 优化
查看>>
2.4 salt grains与pillar jinja的模板
查看>>
MySQL主从(介绍,配置主机,配置从机,测试主从同步)
查看>>
不同版本的outlook客户端配置Office 365 exchange online帐户需要安装的补丁
查看>>
Java服务器-resin
查看>>
Linux下搭建JDK和TOMCAT环境
查看>>
关闭windows休眠
查看>>
Ansible之十一:变量详解
查看>>
那些SCOM 管理包开发中遇到的坑1–Powershell scriptBlock Invoke执行结果的类型
查看>>
关于Server Sql 2008触发器的使用
查看>>
mac常见命令
查看>>