- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我需要存储大量信息,例如 java 列表中的“名称”。项目的数量可以改变(或者简而言之我无法预定义大小)。我认为,从内存分配的角度来看,LinkedList 将是比 ArrayList 更好的选择,因为对于 ArrayList,一旦达到最大大小,内存分配会自动加倍,因此总是有可能分配比 ArrayList 更多的内存需要什么。
我从这里的其他帖子中了解到,存储在 LinkedList 中的单个元素比 ArrayList 占用更多空间,因为 LinkedList 还需要存储节点信息,但我仍然猜测我定义的场景 LinkedList 可能是更好的选择。另外,我不想涉及性能方面(获取、删除等),因为已经讨论了很多。
最佳答案
LinkedList
可能会分配更少的条目,但这些条目比 ArrayList
更昂贵。 -- 足够了,即使是最坏的情况 ArrayList
就内存而言更便宜。
(仅供引用,我认为你弄错了;ArrayList
满时增长 1.5 倍,而不是 2 倍。)
参见例如https://github.com/DimitrisAndreou/memory-measurer/blob/master/ElementCostInDataStructures.txt : LinkedList
每个元素消耗 24 个字节,而 ArrayList
在最好的情况下每个元素消耗 4 个字节,在最坏的情况下每个元素消耗 6 个字节。 (结果可能因 32 位与 64 位 JVM 和压缩对象指针选项而异,但在这些比较中,LinkedList
至少花费 36 个字节/元素,ArrayList
最多为 8,最坏为 12。)
更新:
I understand from other posts here that individual elements stored in a LinkedList takes more space than an ArrayList as LinkedList also needs to store the node information, but I am still guessing for the scenario I have defined LinkedList might be a better option. Also, I do not want to get into the performance aspect (fetching, deleting etc) , as much has already been discussed on it.
要清楚,即使在最坏的情况下,ArrayList
比 LinkedList
小 4 倍具有相同的元素。制作 LinkedList
的唯一可能方法win 是通过调用 ensureCapacity
故意修复比较。故意夸大值,或从 ArrayList
中删除大量值添加后。
简而言之,制作LinkedList
基本上是不可能的。赢得内存比较,如果你关心空间,然后调用 trimToSize()
在 ArrayList
将立即使ArrayList
再次以巨大的优势获胜。严重地。 ArrayList
赢了。
关于java - 从内存分配的角度来看 ArrayList 与 LinkedList,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11564352/
在我开发和维护的代码中遇到了一个问题。 我有一个函数,它接受查询(类型字符串)并用不同的字符串替换该字符串的子字符串。例如,如果用户输入字符串“我有一只猫”,它会将其替换为“我有一只狗”。 我的代码可
有很多工具可以解决浏览器前缀问题,无论是 IDE 自动扩展麻烦的属性还是使用预编译器进行混合,但为什么浏览器制造商确实需要实现前缀。据我所知,他们可以实现自己的某些实现,但是什么阻止他们在没有前缀的情
我需要存储重要的 oauth 授予 token ,这些 token 应该防篡改。 传统 Cookie 和 HTML5 本地存储哪一个更安全? 最佳答案 没有什么是防篡改的——至少,永远不要假设它是防篡
$("*").click(function(){...}) 是否被认为昂贵? - See here . 在每次点击时发送 ajax 请求怎么样? 这会对普通用户造成明显的(性能?)问题吗?该应用程序不
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我想创建一个简单的 docker-compose 设置。我有一个在 JS 中实现的静态前端,由 nginx 提供服务——这是一个容器。我还有一个 API 后端 Web 服务器 - 另一个容器。 我可以
我对 JavaScript 的理解是,在脚本执行时会创建一个全局执行上下文 - 我理解为保留内存空间中的一系列键:值对 - 很像常规的 JavaScript 对象。 在函数执行时,会创建一个新的执行上
我不得不使用第 3 方 CMS,我无法更改 h3 的内容(或 h3 本身) 我对“cufon”没有太多的了解——假设它是一种使用特定字体的老式方法。我猜它不是合法的 HTML,所以没有编入索引。 因此
上面你有一个按钮有3种状态,normal,hover,那么第三种状态叫什么?需要在我的 CSS 中添加什么来设置样式? 右键单击后按钮似乎也处于此状态。 可能真的很简单,我知道,但我想不通。 最佳答案
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
我有 knockoutjs+requirejs 背景。 我切换到angularjs。 我不喜欢 angularjs 中的每个绑定(bind)属性都只是附加到 Controller 内部的 $scope
例如,我有一个视口(viewport) 100px * 100px和 8 . 他们每个人都有风格: position: absolute; top: 0px; left: 0px; bottom:
我很好奇为我的社交媒体图标使用 CSS 图像 Sprite 与使用自定义 UI 字体的优缺点。 哪一个将在页面加载速度方面提供卓越的性能? 在我看来,CSS Sprite 可能更好 - 因为只有一个
我知道类 API 在 Vue 3 中被删除了。这意味着不会有开箱即用的基于类的语法。 在vue-class-component 中,我不知道是哪种魔法将TypeScript 编写的Vue 类转换为有效
这个问题在这里已经有了答案: HTML5 nav element vs. role="navigation" (6 个回答) 5 天前关闭。 社区在5天前审核了是否重新打开这个问题并关闭了它: 重复
在有人考虑否决甚至关闭我的问题之前,我想强调一下,我并不是在问哪个更好(这当然是一个无意义的问题,特别是当我们认为一个专注于服务器端而另一个专注于浏览器端时)。 来自http://winterbe.c
我使用 Angular 1.4.x 和 prerender.io 设置了一个网站,该网站向 googlebot 提供渲染的静态缓存页面。Googlebot 会抓取每个页面两次。一次抓取命中了 URL,
我是一名优秀的程序员,十分优秀!