import java.util.ArrayList; import java.util.LinkedList; import java.util.List; import java.util.Random; import java.util.List; import java.util.ArrayList; import java.util.LinkedList; import java.util.Date; public class TestList { public static void main(String[] args) { List<Integer> arrayList = new ArrayList<Integer>(); List<Integer> linkList = new LinkedList<Integer>(); insertTest(linkList);// 2 ms insertTest(arrayList);// 977 ms getTest(linkList);// 2475 ms getTest(arrayList);// 3 ms } public static void insertTest(List<Integer> list) { for (int i = 0; i < 5000; i++) {// 创建数据表 for (int j = 1; j < 1000; j++) { list.add(i + j); } } Long begin = new Date().getTime(); for (int i = 3; i < 1000; i += 3) {// 插入数据 list.add(i, i); } Long end = new Date().getTime(); System.out.println("cost : " + (end - begin) + " ms"); System.out.println("number:" + list.size()); } public static void getTest(List<Integer> list) { for (int i = 0; i < 5000; i++) {// 创建数据 for (int j = 1; j < 1000; j++) { list.add(j); } } Long begin = new Date().getTime(); for (int i = 3; i < 50000; i++) {// 插入数据 list.get(i); } Long end = new Date().getTime(); System.out.println("cost : " + (end - begin) + " ms"); System.out.println("number:" + list.size()); } /** * 总结: 1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。 * 2.对于随机访问get和set,ArrayList优于LinkedList,因为LinkedList要移动指针。 * 3.对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据 **/ }