- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发我的 java 应用程序,我很关心性能速度,特别是因为我有很多数据结构,如列表、映射等。
我知道 LinkedList 的 add(Object obj) 方法的复杂度是 O(1) (使用 LinkedList 的主要原因),ArrayList 的 get(int index) 方法的复杂度是 O(1) (主要原因使用ArrayList)。
我在互联网上找到了以下文章:
Try to follow these rules while optimizing ArrayList performance of your code:
Add elements to the end of the list
Remove elements from the end too
Avoid contains, indexOf and remove(Object) methods
Even more avoid removeAll and retainAll methods
Use subList(int, int).clear() idiom to quickly clean a part of the list
现在我需要知道的是,将元素添加到列表末尾意味着什么,因为就我而言,如果我们不使用索引作为 add 方法的参数,换句话说,如果我们使用 add( Object obj) 方法,然后元素总是添加到末尾。
我有下面这两种方法,我想知道当我们有 1000 个文件时这些方法的性能是否令人满意。如果没有,有什么办法可以提高性能
我已经使用像 jvm 这样的分析器来测量速度性能,但我仍然不确定这是否是我可以实现的最佳性能
public List<int[][]> AllSharesForFiles (int n , int k,List<File> file) {
sharesHolder = new LinkedList<int[][]>();
try{
for(int i=0;i<file.size();i++) {
byte[]secret = f.readingTheFile(file.get(i)); // We call the method which read the file
//method which evaluate the shares of each byte of the file
shar1= s.calculateThresholdScheme(secret, n,k,new RndGeneratorAllAlgorithm(new RandomGeneratorSHA1()),two);
sharesHolder.add(shar1);
}
} catch (IOException e) {
e.printStackTrace();
}
return sharesHolder;
}
/*Look for the possibilities to return a 2D array instead of one dimensional array
*
*/
public List<int[][]> AllSharesForEachFile (int n , int k,List<int [] []> f) {
sharesHolder1 = new LinkedList<int[][]>();
int s=f.size();
int l=f.get(1)[0].length;
for (int i = 0; i < n; i++) {
someValue=new int[s][l];
for(int j=0;j<f.size(); j++){
someValue[j]=f.get(j)[i];
}
sharesHolder1.add(someValue);
}
return sharesHolder1;
}
最佳答案
对于绝大多数用例,
ArrayList
优于 LinkedList
。看看this Q&A讨论它们的性能差异。
简而言之,ArrayList
对于 add(Object o)
的摊销复杂度为 O(1)。它们的优点还在于拥有更好的缓存局部性,因为所有项目都分配在单个内存块中,而不是分散在整个堆中,后者的成本相当高,因为它需要额外的间接寻址。
也就是说,您担心性能是件好事,但如果您需要处理的只是一个包含 1000 个项目的列表,您可能会发现两种实现之间存在一些差异。您的列表并没有那么大,而且您还将列表上的操作与 I/O 操作混合在一起,这肯定会主导应用程序的执行时间。
关于java - List 的每个子项的 add 方法和 get 方法的速度有多快,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37912250/
我想使用 R 预定义这样的列表 DATA<-list( list(list(),list(),list()), list(list(),list(),list()), list(list(),l
如何将一个列表添加到另一个列表,返回一个列表的列表? foo :: [a] -> [a] -> [[a]] 例如,我想要的结果是: foo [1,2] [3,4] 将是 [[1,2], [3,4]]。
我还没有在这里找到类似问题的解决方案,所以我会寻求你的帮助。 有 2 个列表,其中之一是列表列表: categories = ['APPLE', 'ORANGE', 'BANANA'] test_re
这个问题不同于Converting list of lists / nested lists to list of lists without nesting (这会产生一组非常具体的响应,但无法解决
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在下面的代码中,get()被调用并将其结果分配给类型为 List> 的变量. get()返回 List>并在类型参数为 T 的实例上调用设置为 ? ,所以它应该适合。 import java.util
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在insufficiently-polymorphic 作者说: def foo[A](fst: List[A], snd: List[A]): List[A] There are fewer way
我有下面的代码有效。 class ListManipulate(val list: List, val blockCount: Int) { val result: MutableList>
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
在 scala (2.9) 中转换列表列表的最佳方法是什么? 我有一个 list : List[List[A]] 我想转换成 List[A] 如何递归地实现这一点?或者还有其他更好的办法吗? 最佳答案
我编写了这个函数来确定给定元素是否存储在元组列表的列表中,但目前它只搜索第一个列表。我将如何搜索其余列表? fun findItem (name : command, ((x,y)::firstlis
我创建了一个类名 objectA,它有 4 个变量:约会时间;字符串文本;变量 1,变量 2 我需要创建一个 ObjectA() 列表。然后首先按时间对它们进行分组,其次按 var1,然后按 var2
我有一套说法 char={'J','A'} 和列表的列表 content = [[1,'J', 2], [2, 'K', 3], [2, 'A', 3], [3,'A', 9], [5, 'J', 9
我有以下列表 List >>> titles = new ArrayList >>> ();我想访问它的元素,但我不知道该怎么做.. 该列表有 1 个元素,它又包含 3 个元素,这 3 个元素中的
转换 List[List[Long]] 的最佳方法是什么?到 List[List[Int]]在斯卡拉? 例如,给定以下类型列表 List[List[Long]] val l: List[List[Lo
我有一个来自 Filereader (String) 的 List-List,如何将其转换为 List-List (Double):我必须返回一个包含 line-Array 的第一个 Values 的
我收集了List> 。我需要将其转换为List> 。这是我尝试过的, List> dataOne = GetDataOne(); var dataTwo = dataOne.Select(x => x
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
我是一名优秀的程序员,十分优秀!