- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在用 java 编写一个数据结构链表(为了我的学习,我没有使用任何标准的 java 库),我想通过引用 null 来清除数据结构。请建议我哪种方法更好
1) 将列表的起始引用设为 null 就足够了。
2) 除了将 start 置空外,我将所有内部节点的所有 next 指针都取消引用为 null。这对垃圾收集器有任何帮助吗?
我看到方法 2 中的混淆在 JDK 中用于 LinkedList 实现。但我没有看到 TreeMap 相同
我正在使用 JDK 8
最佳答案
这是一个有趣的问题,答案有着悠久的历史,但也有微妙的权衡。
简短的回答是,数据结构的正确操作不需要清除引用。由于您正在学习数据结构,因此我建议您不要在自己的实现中担心这个问题。我的预感(虽然我没有对此进行基准测试)是,在典型条件下,清除所有链接节点可能带来的任何好处都很少被注意到。
(此外,在典型条件下, LinkedList
的表现可能会优于 ArrayList
或 ArrayDeque
。有 是 基准测试说明了这一点。但在其他情况下,人们认为 LinkedList
的工作量比其他人更难.)
我很惊讶地得知 clear
的 LinkedList
操作将所有节点彼此断开以及与包含的元素断开链接。这是 code in JDK 8 的链接。此更改可追溯到 2003 年,此更改出现在 JDK 5 中。此更改由错误 JDK-4863813 跟踪。当单个节点从列表中取消链接时,该更改(或稍早的更改)会清除来自单个节点的下一个和上一个引用。那个错误报告中还有一个测试用例,这很有趣。
问题似乎是可以对 LinkedList
进行更改,这会创建垃圾节点,比垃圾收集器回收它们的速度更快。这最终会导致 JVM 内存不足。垃圾节点全部链接在一起的事实似乎也具有阻碍垃圾收集器的效果,使 mutator 线程更容易超过收集器线程。 (我不清楚让多个线程改变列表有多重要。在测试用例中,它们都在列表上同步,因此没有实际的并行性。)更改为 LinkedList
以取消节点之间的链接使其更容易让收集器完成其工作,因此显然使测试不再耗尽内存。
快进到 2009 年,当时 LinkedList
代码进行了“整容”。这由错误 JDK-6897553 跟踪并在此 email review thread 中讨论。 “整容”的最初动机之一是将 clear()
操作从 O(n) 减少到 O(1),因为对于该错误的提交者来说,取消所有节点的链接似乎是不必要的。 (这对我来说似乎没有必要!)但是经过一些讨论,决定取消链接行为为垃圾收集器提供了足够的好处来保留它并记录它。
该评论还说取消链接节点
is sure to free memory even if there is a reachable Iterator
// fields in some class
List<Obj> list = createAndPopulateALinkedList();
Iterator<Object> iterator;
void someMethod() {
iterator = list.iterator();
// ...
list.clear();
}
clear()
中的所有节点可以收集这些节点。不过,我认为这是非常病态的,因为迭代器很少存储在字段中。通常迭代器是在单个方法中创建、使用和丢弃的,最常见的是在单个
for
循环中。
TreeMap
。我不认为
LinkedList
取消链接其节点而
TreeMap
没有的根本原因。人们可能会认为整个 JDK 代码库是一致维护的,因此如果
LinkedList
取消链接其节点是一种好的做法,那么这也应该对
TreeMap
进行。唉,事实并非如此。最有可能发生的情况是,客户遇到了
LinkedList
的病态行为,并在那里进行了更改,但没有人观察到
TreeMap
的类似行为。因此没有动力更新
TreeMap
。
关于关于清除链表的 Java 最佳实践,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33935980/
我有一个网站,我正在通过学校参加比赛,但我在清除 float 元素方面遇到了问题。 该网站托管在 http://www.serbinprinting.com/corey/development/
我有一个清除按钮,需要使用 JQuery 函数清除该按钮单击时的 TextBox 值(输入的)。 最佳答案 您只需将单击事件附加到按钮即可将输入元素的值设置为空。 $("#clearButton").
我们已经创建了一个保存到 CoreData 然后同步到 CloudKit 的 iOS 应用程序。在测试中,我们还没有找到一种方法来清除应用程序 iCloud 容器中的数据(用于用户私有(private
这是一个普遍的问题,也是我突然想到并且似乎有道理的问题。我看到很多人使用清除div 并且知道这有时不受欢迎,因为它是额外的标记。我最近开始使用 因为它接缝代表了它的实际用途。 当然都引用了:.clea
我有两个单选按钮。如果我检查第一个单选按钮下面的数据将填充在组合框中。之后我将检查另一个单选按钮,我想清除组合框值。 EmployeeTypes _ET = new EmployeeTypes(
我一直在玩 Canvas ,我正在尝试制作一个可以移动和跳跃的正方形,移动部分已经完成,但是跳跃部分有一个问题:每次跳跃时它都会跳得更快 here's a jsfiddle 这是代码: ///////
我该如何在 Dart 上做到这一点? 抓取tbody元素后,我想在其上调用empty(),但这似乎不存在: var el = query('#search_results_tbody'); el.em
我需要创建一个二维模拟,但是在设置新的“框架”时,旧的“框架”不会被清除。 我希望一些圆圈在竞技场中移动,并且每个循环都应删除旧圆圈并生成新圆圈。一切正常,但旧的没有被清除并且仍然可见,这就是我需要改
无论我使用set statusline将状态行更改为什么,我的状态行都不会改变。看起来像 ".vimrc" 39L, 578C
在 WPF 应用程序中,我有一个 ListView 绑定(bind)到我的 ViewModel 上的一个 ObservableCollection。 在应用程序运行期间,我需要删除并重新加载集合中的所
我有一个大型程序,一个带有图形的文本扭曲游戏。在我的代码中的某处,我使用 kbhit() 我执行此代码来清除我的输入缓冲区: while ((c = getchar()) != '\n' && c !
我正在将所有网站的页面加载到主索引页面中,并通过将 href 分成段并在主域名后使用 .hash 函数添加段来更新 URL 显示,如下所示: $('a').click(function(event)
我有一个带有 的表单和 2 控件来保存和重置表单。我正在触发 使用 javascript __doPostBack()函数并在其中传递一个值 __EVENTARGUMENT如果面板应该重置。 我的代
我目前有一堆 UIViewController,每个都是在前一个之上呈现的模式 ViewController。我的问题是我不需要一堆 UIViewController,我只需要最后一个。因此,当出现新
我在一个类中有一些属性方法,我想在某个时候清除这个属性的缓存。 示例: class Test(): def __init__(self): pass @property
在此Test Link我试图将标题和主站点导航安装到博客脚本的顶部。 我清除:两者;在主要网站脚本上工作,但现在把所有东西都扔到了一边。尝试了无数次 fixex 都没有成功!提前感谢 Ant 指点解决
我似乎无法正确清除布局。看this 我无法阻止左栏中的元素向下推右栏中的元素。谁能帮忙? Screenshot with some pointy arrows (死链接) 最佳答案 问题标记/样式似
我希望能够在某个类 (sprite-empos) 之后清除 '' 中的内容,想知道是否有不添加任何新类或不使用 js 的方法(我在下面尝试过不工作)? 为了明确它是“985”,我想在某个视口(view
我想清除ptr_array boost::ptr_array a; ... a.clear(); // missing 如何清理 ptr 容器? 最佳答案 它应该表现得像一个数组,您不能在 C++
这是我使用多 map 制作的一个简单的事件系统;当我使用 CEvents::Add(..) 方法时,它应该插入并进入多重映射。问题是,当我触发这些事件时, multimap 似乎是空的。我确定我没有调
我是一名优秀的程序员,十分优秀!