JAVA [ 性能优化 ArrayList LinkedList]

本文通过代码实验证明了Java中ArrayList和LinkedList在不同操作上的性能差异,包括添加、获取、移除元素等。实验结果揭示了两种数据结构在实际应用中的优缺点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

效果比较:

=========ArrayList AddLast=====================
109ms
=========LinkedList AddLast=====================
94ms
=========ArrayList AddFirst=====================
2297ms
=========LinkedList AddFirst=====================
171ms
=========ArrayList Get=====================
0ms
=========LinkedList Get======================
17938ms
=========ArrayList Remove=====================
2172ms
=========LinkedList Remove======================
15ms


源代码:

public class CompareTest {

    private static long startTime;
    private static long endTime;
    
    public static void compare_ArrayList_LinkedList(){
        
        LinkedList<Person> l = new LinkedList<Person>();
        LinkedList<Person> l2 = new LinkedList<Person>();    
        Iterator<Person> itl;  
        ArrayList<Person> a = new ArrayList<Person>();  
        ArrayList<Person> a2 = new ArrayList<Person>();       
        Iterator<Person> ita;  
          
        System.out.println("=========ArrayList AddLast=====================");  
        startTime = System.currentTimeMillis();  
        for (int n = 0; n < 50000; n++) {  
            a.add(new Person(Integer.toString(n)));  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
        
        System.out.println("=========LinkedList AddLast=====================");  
        startTime = System.currentTimeMillis();  
        for (int n = 0; n < 50000; n++) {  
            l.add(new Person(Integer.toString(n)));  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
          
        System.out.println("=========ArrayList AddFirst=====================");  
        startTime = System.currentTimeMillis();      
        for (int n = 0; n < 50000; n++) {  
            a2.add(0,new Person(Integer.toString(n)));  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
        
        System.out.println("=========LinkedList AddFirst=====================");  
        startTime = System.currentTimeMillis();  
        for (int n = 0; n < 50000; n++) {  
            l2.addFirst(new Person(Integer.toString(n)));  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
          
          
          
        itl = l.iterator();  
        ita=a.iterator();  
          
        System.out.println("=========ArrayList Get=====================");  
         startTime = System.currentTimeMillis();  
        for(int i=0;i<a.size();i++){  
            a.get(i);  
        }  
         endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
        
        System.out.println("=========LinkedList Get======================");  
        startTime = System.currentTimeMillis();  
        for(int i=0;i<l.size();i++){  
            l.get(i);  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
          
        System.out.println("=========ArrayList Remove=====================");  
        startTime = System.currentTimeMillis();  
        while (ita.hasNext()) {  
            ita.next();  
            ita.remove();  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
        
        System.out.println("=========LinkedList Remove======================");  
        startTime = System.currentTimeMillis();  
        while (itl.hasNext()) {  
            itl.next();  
            itl.remove();  
        }  
        endTime = System.currentTimeMillis();  
        System.out.println(endTime - startTime + "ms");  
    }
    
    public static void main(String[] args){
        compare_ArrayList_LinkedList();
    }
}

class Person {  
    private String name;  
 
    public Person(String n) {  
        this.name = n;  
    }  
 
    public String getName() {  
        return this.name;  
    }  



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值