编程语言
首页 > 编程语言> > 是否有比Java List更长的内容?

是否有比Java List更长的内容?

作者:互联网

我似乎无法找到最大长度为long的最大值的Java List.

这样的清单存在吗?

如果是的话,在哪里?

解决方法:

正如@afsantos所说,由于Java数组的限制,ArrayList类本质上仅限于Integer.MAX_VALUE条目.

LinkedList没有这个限制,但它(但仍然)昂贵:

>每个条目都会产生2个引用的内存开销加上对象头的大小…与基于数组的表示的一个引用相比.
>与基于阵列的列表的O(1)相比,索引是O(N)操作.

以下是Java库的链接,该库使用直接映射内存和/或元素编码支持大量内存中集合:

> http://code.google.com/p/vanilla-java/wiki/HugeCollections

那里可能还有其他选择.

人们还可以设想使用数组数组而不是单个数组的常规数组列表的“大”变体.但是如果允许插入到列表的中间,则实现O(1)查找变得困难/昂贵. (这可能就是为什么我找不到谷歌的例子……)

标签:maxlength,java,long-integer,arraylist
来源: https://codeday.me/bug/20191002/1841238.html