java 中ArrayList与LinkedList机能较量
java 中ArrayList与LinkedList机能较量 本日看一框架的代码,看到有些 可以行使ArrayList的处所 行使的是 LinkedList,用到的景象是在一个轮回内里举办次序的插入操纵。 众所周知java内里List接口有两个实现ArrayList 和 LinkedList,他们的实现道理别离是c说话中先容的数组和链表。 正如进修数据布局时的熟悉,对付插入操纵,链表的布局更高效,缘故起因是可以通过修改节点的指针 就可以完成插入操纵, 而不像数组, 必要把插入位置之后的数组元素依次后移。 可是,现实环境真如上面假想一样吗,下面通过一个简朴的例子实践,看能得出什么结论。 public static void main(String[] args) { List<String> arrayList = new ArrayList<String>(); List<String> linkedList = new LinkedList<String>(); long time1 = System.currentTimeMillis(); for(int i = 0; i < 1000000; i++) { arrayList.add(new String("abc")); } long time2 = System.currentTimeMillis(); for(int i = 0; i < 1000000; i++) { linkedList.add(new String("abc")); } long time3 = System.currentTimeMillis(); System.out.println("arrayList.insert_time = " + (time2 - time1)); System.out.println("linkedList.insert_time = " + (time3 - time2)); long time11 = System.currentTimeMillis(); for(int i = 0; i < 10000; i++) { int random = RandomUtils.nextInt(10000); String temp = arrayList.get(random); } long time12 = System.currentTimeMillis(); for(int i = 0; i < 10000; i++) { int random = RandomUtils.nextInt(10000); String temp = linkedList.get(random); } long time13 = System.currentTimeMillis(); System.out.println("arrayList.read_time = " + (time12 - time11)); System.out.println("linkedList.read_time = " + (time13 - time12)); } 运行功效: arrayList.insert_time = 188 linkedList.insert_time = 250 arrayList.read_time = 16 linkedList.read_time = 234 通过功效可以看出:无论什么环境,ArrayList越发高效。尤其对付随机读取,数组的服从是链表的14倍之多。 而插入操纵,两者用时相差不多,可是照旧数组的实现服从高一些。 对付个华夏因,细心想想也不难想大白。 当List存储的内容不多时,写入List的最后的元素,ArrayList和LinkedList用时差不多。 可是当List存储的元素个数很大时,通过数组布局实现的ArrayList插入到最后可以通过数组下标很快会见到,可是LinkedList就必要会见每个节点直到找到最后的元素再举办插入操纵,这中操纵步调的耗时是庞大的,以是列表数目越大,LinkedList就越感吃力了。 虽然,对付要求随机插入的场景,这个时辰LinkedList就要比ArrayList得当了。 感激阅读,但愿能辅佐到各人,感谢各人对本站的支持! (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |