java中垃圾收集的方法有哪些?王庆明

一、引用计数算法(ReferenceCounting)

介绍:给对象添加一个引用计数器,每当一个地方引用它时,数据器加1;当引用失效时,计数器减1;计数器为0的即可被回收。

优点:实现简单,判断效率高

缺点:很难解决对象之间的相互循环引用(objA.instance=objB;objB.instance=objA)的问题,所以java语言并没有选用引用计数法管理内存

二、根搜索算法(GCRootTracing)

Java和C#都是使用根搜索算法来判断对象是否存活。通过一系列的名为“GCRoot”的对象作为起始点,从这些节点开始向下搜索,搜索所有走过的路径称为引用链(ReferenceChain),当一个对象到GCRoot没有任何引用链相连时(用图论来说就是GCRoot到这个对象不可达时),证明该对象是可以被回收的。

在Java中哪些对象可以成为GCRoot

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

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

方法区中的常量引用对象

本地方法栈中JNI(即Native方法)的引用对象

三、标记-清除算法(Mark-Sweep)

这是垃圾收集算法中最基础的,根据名字就可以知道,它的思想就是标记那些要被回收的对象,然后统一回收。这种方法很简单,但是会有两个主要问题:

1.效率不高,标记和清除的效率都很低;

2.会产生大量不连续的内存碎片,导致以后程序在分配交大的对象时,由于没有充足的连续内存而提前触发一次GC动作。

四、复制算法(Copying)

为了解决效率问题,复制算法将可用内存按容量划分相等的两部分,然后每次只使用其中的一块,当第一块内存用完时,就将还存活的对象复制到第二块内存上,然后一次性清除完第一块内存,在将第二块上的对象复制到第一块。但是这种方式,内存的代价太高,每次基本上都要浪费一块内存。

于是将该算法进行了改进,内存区域不再是按照1:1去划分,而是将内存划分为8:1:1三部分,较大的那份内存叫Eden区,其余两块较小的内存叫Survior区。每次都会先使用Eden区,若Eden区满,就将对象赋值到第二块内存上,然后清除Eden区,如果此时存活的对象太多,以至于Survivor不够时,会将这些对象通过分配担保机制赋值到老年代中。(java堆又分为新生代和老年代)。

五、标记-整理算法(Mark-Compact)

该算法是为了解决标记-清楚,产生大量内存碎片的问题;当对象存活率较高时,也解决了复制算法的效率问题。它的不同之处就是在清除对象的时候现将可回收的对象移动一端,然后清除掉端边界以为的对象,这样就不会产生内存碎片。

六、分代收集算法(GenerationalCollection)

根据对象的存活周期的不同将内存划分为几块,一般就分为新生代和老年代,根据各个年代的特点采用不同的收集算法。新生代(少量存活)用复制算法,老年代(对象存活率高)“标记-清理”算法

补充:分代划分内存介绍

整个JVM内存总共划分为三代:年轻代(YoungGeneration)、年老代(OldGeneration)、持久代(PermanentGeneration)

1、年轻代:所有新生成的对象首先都放在年轻代内存中。年轻代的目标就是尽可能快速的手机掉那些生命周期短的对象。年轻代内存分为一块较大的Eden空间和两块较小的Survior空间,每次使用Eden和其中的一块Survior.当回收时,将Eden和Survior中还存活的对象一次性拷贝到另外一块Survior空间上,最后清理Eden和刚才用过的Survior空间。

2、年老代:在年轻代经历了N次GC后,仍然存活的对象,就会被放在老年代中。因此可以认为老年代存放的都是一些生命周期较长的对象。

3、持久代:基本固定不变,用于存放静态文件,例如Java类和方法。持久代对GC没有显著的影响。持久代可以通过-XX:MaxPermSize=进行设置。

THE END
1.最优化导论全局搜索算法全局搜索算法有哪些全局搜索算法 1. 引言 全局意义上的搜索方法能够在整个可行集上开展搜索,以找到极小点。这些方法只需要计算函数目标值,不需要对目标函数进行求导。这类方法的适用面更加广阔,在某些情况下,这些方法产生的解可以作为如梯度方法、牛顿法等迭代方法的“较好”的初始点。 https://blog.csdn.net/qq_33414271/article/details/100026094
2.科技前沿什么是AI搜索?与传统搜索有何区别?AI搜索与传统搜索有什么区别? AI搜索和传统搜索的区别主要在于,其使用了更为先进的人工智能技术,使其具有更强的理解能力、更精准的回答以及更高效的信息获取。 在传统搜索中,用户查询某些关键词,得到一些网页之后,他需要主动的去阅读这些内容,还要进行甄别https://mp.weixin.qq.com/s?__biz=MzIyOTQwMDkxNQ==&mid=2247592047&idx=3&sn=08dc1eaa18c18eb9fb69ba8a20d2933b&chksm=e96e59eb172bb6ba25fe928a814f496023ba89f092199a1b90146b828aa73a6b34d5a0752a6a&scene=27
3.编程中常见的算法介绍在编程中,有许多常见的算法可以用来解决各种问题。以下是一些常见的算法:①.线性搜索算法(Linear Search):按顺序查找列表中的元素,直到找到目标元素或遍历完整个列表。线性搜索算法是最简单的搜索算法之一。它从列表的第一个元素开始逐个向后查找,直到找到目标元素或遍历完整个列表。该算法的时间复杂度为O(n),https://baijiahao.baidu.com/s?id=1798899821822273065&wfr=spider&for=pc
4.数组的搜索算法有哪些?C++数组的搜索算法有哪些? 数组搜索算法大全:线性搜索:遍历数组,时间复杂度 o(n)。二分搜索(仅限有序数组):将数组二分,时间复杂度 o(log n)。哈希表:使用键值快速查找,时间复杂度 o(1)。 数组搜索算法大全 在计算机科学中,数组搜索算法用于在有序或无序数组中找到特定元素。本文将探讨各种数组搜索算法,包括其https://www.php.cn/faq/802377.html
5.搜索引擎算法的种类有哪些?搜索引擎算法是促进互联网搜索能力发展的关键力量。它是一种专业的算法,负责收集、筛选和排序从网络上搜索到的信息,以满足用户的查询需求。在做SEO优化的过程中,也需要符合搜索引擎的算法,这样网站才能获得一个理想的排名。 那么,搜索引擎算法的种类有哪些? 1、内容https://www.batmanit.cn/blog/e/128.html
6.搜索策略架构搜索策略有哪些bingfeng的技术博客OPEN表:类似NPS表,记录了已生成但其子状态待考察的节点。宽度优先搜索算法中OPEN表是队列结构,其中状态的排列次序就是搜索的次序。 CLOSED表:相当于PS表和NSS表的合并,记录了已被生成扩展过的状态。 宽度优先搜索过程: 把起始节点放到OPEN表中。 如果OPEN是个空表,则没有解, 失败退出,否则继续。 https://blog.51cto.com/u_13229/8894941
7.做百度SEO不行了?SEO如何转行与转行方向有哪些?3、百度自然搜索结果被快排把控,惊雷算法真的有心无力? 关于快排这个,我很久以前有误解,觉得快排就是不好的,但跟朋友聊了以后才发现,之所以产生这个LOUDONG,归根结底还是所谓用户数据的锅,真是成也萧何,败了萧何。 百度排名,给了用户搜索点击很大权重,那么,用户搜索什么词的点击,而这个点击行为被快排行业从业解密https://lusongsong.com/reed/14403.html
8.C#刷遍Leetcode面试题系列连载(1)入门与工具简介刷LeetCode有哪些好处? 计算机中有很多抽象的数据结构,比如: List、Stack(栈)、Linked List(链表)、Hash Table(哈希表)、Heap(堆)、Tree等等,而LeetCode 上的大量高质量算法题基本上涵盖了所有这些数据结构的应用。怎么将这些题抽象成数学模型,转化为具体数据结构的应用,则是我们需要提升的地方,而这恰恰帮我们极大https://www.shangyexinzhi.com/article/details/id-258758
9.JVM高频面试题合集我们可以看到,三个对象各自指向循环中的另一个对象,但是没有其他引用指向这三个对象,那这三个对象就属于“一堆垃圾”。 那现在我们上面所说的引用计数就不能解决这个该问题,这时我们就需要使用另外一种定位方式——Root Searching(根可达算法或根搜索算法)。 https://www.tulingxueyuan.cn/tlzx/javamst/5513.html
10.常见的搜索算法有哪几种?全国分支限界算法(Branch-and-boundSearchAlgorithm)https://www.1633.com/ask/150851.html
11.算法与言论——美国的理论与实践在一定程度上,搜索王案有些类似冷战时期爆发在“边缘”地区的代理人战争:它虽然只发生在俄克拉荷马州的一家地区法院(而非联邦巡回法院或最高法院),但它背后则是两种力量和两大阵营的集结和较量。双方围绕算法规制展开的第一场较量,是以言论自由开始并以言论自由的胜利而告终的。https://ciss.tsinghua.edu.cn/info/xzgd/119
12.搜索引擎有哪几种算法?SEO必知的搜索引擎九大算法解析网站优化作为SEOER的你,还不知道就out啦,本文将提供SEO必知的九大搜索引擎算法解析供大家了解,希望对大家有所帮助和启发 GPT4.0+Midjourney绘画+国内大模型 会员永久免费使用! 【如果你想靠AI翻身,你先需要一个靠谱的工具!】 搜索引擎发展至今,已公布了多种算法。了解算法知识并不懂得如何把算法实践于SEO工作的你,还是处于https://www.jb51.net/yunying/459656.html
13.常见算法5广度优先搜索BreadthFirstSearch广度优先搜索(Breadth-First Search)是最简便的图的搜索算法之一,又称宽度优先搜索,这一算法也是很多重要的图算法的原型。广度优先搜索属于一种盲目搜寻法,目的是系统地展开并检查图中的所有节点,以找寻结果。换句话说,它并不考虑结果的可能位置,彻底地搜索整张图,直到找到结果为止。 https://www.jianshu.com/p/c6b89506e5c5
14.自动驾驶路径规划五大常用算法汽车技术Dijkstra算法不同之处在于,A* 算法是一个“启发式”算法,它已经有了一些我们告诉它的先验知识,如“朝着终点的方向走更可能走到”。它不仅关注已走过的路径,还会对未走过的点或状态进行预测。因此A* 算法相较于Dijkstra而言,调整了进行BFS的顺序,少搜索了哪些“不太可能经过的点”,更快地找到目标点的最短路径。https://www.auto-testing.net/news/show-116633.html
15.程序员应该知道的十个基础算法腾讯云开发者社区2.快速排序:快速排序是一种常用且高效的排序算法。它采用递归的方式将问题划分为更小的子问题,并使用一个基准元素进行排序。 3.归并排序:归并排序采用分治策略,将问题逐步细化并通过合并操作得到最终的有序结果。 二. 搜索算法 1.二分查找:二分查找适用于有序数组,它将目标值与数组的中间元素进行比较,从而缩小搜https://cloud.tencent.com/developer/article/2352039
16.搜推广算法关键知识点尽管不同召回算法有不同的loss,但是背后基于Pairwise LTR的思想都是共通,这一点与排序时采用binary cross entropy loss有较大的不同。 比如Youtube/DSSM模型使用(Sampled) Softmax。但经过Negative Sampling之后,同样是针对同一个用户,一个d+要配置若干个d?,与Pairwise思路类似 而想让u在d+上的得分最高,同样https://zhuanlan.zhihu.com/p/689575936