1.單線程方式html
2.多線程版本,不安全的 ArrayListjava
3.多線程版本,線程安全,CopyOnWriteArrayList()方式安全
4.多線程版本,線程安全,Collections.synchronizedList方式多線程
1 import java.util.ArrayList; 2 import java.util.Collections; 3 import java.util.List; 4 import java.util.concurrent.CopyOnWriteArrayList; 5 import java.util.concurrent.ExecutorService; 6 import java.util.concurrent.Executors; 7 8 /** 9 * @author zsh 10 * @site qqzsh.top 11 * @create 2019-08-26 11:53 12 * @description Collections.synchronizedList與CopyOnWriteArrayList比較 13 * https://liuyanzhao.com/9732.html 14 */ 15 public class Main3 { 16 17 /** 18 * 單線程:性能較差 19 */ 20 static void f1(){ 21 Long startTime = System.currentTimeMillis(); 22 //這是一個長度爲1000的集合 23 List<Long> sourceList = new ArrayList<>(); 24 for (long i = 0L; i < 1000L; i++) { 25 sourceList.add(i); 26 } 27 System.out.println("原列表大小:" + sourceList.size()); 28 //對原列表進行處理 29 List<Long> resultList = new ArrayList<>(); 30 for (Long x : sourceList) { 31 //模擬耗時操做(x累加300萬次) 32 Long sum = 0L; 33 for (long i = 0L; i < 3000000L; i++) { 34 sum += x; 35 } 36 resultList.add(sum); 37 } 38 System.out.println("處理後的列表大小:" + resultList.size()); 39 System.out.println("耗時:" + (System.currentTimeMillis() - startTime) + "ms"); 40 } 41 42 /** 43 * 多線程版本,不安全的 ArrayList 44 */ 45 static void f2(){ 46 Long startTime = System.currentTimeMillis(); 47 ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10); 48 //這是一個長度爲1000的集合 49 List<Long> sourceList = new ArrayList<>(); 50 for (long i = 0L; i < 1000L; i++) { 51 sourceList.add(i); 52 } 53 System.out.println("原列表大小:" + sourceList.size()); 54 List<Long> resultList = new ArrayList<>(); 55 for (Long x : sourceList) { 56 fixedThreadPool.execute(new Runnable() { 57 @Override 58 public void run() { 59 //對原列表進行處理 60 //模擬耗時操做(x累加300萬次) 61 Long sum = 0L; 62 for (long i = 0L; i < 3000000L; i++) { 63 sum += x; 64 } 65 resultList.add(sum); 66 } 67 }); 68 } 69 fixedThreadPool.shutdown();//關閉線程池 70 //此處不能夠刪除或註釋,須要線程執行結束後再執行別的內容,即只有線程結束後纔會繼續向下執行 71 while (!fixedThreadPool.isTerminated()) { 72 } 73 System.out.println("處理後的列表大小:" + resultList.size()); 74 System.out.println("耗時:" + (System.currentTimeMillis() - startTime) + "ms"); 75 } 76 77 /** 78 * 多線程版本,線程安全,CopyOnWriteArrayList()方式 79 */ 80 static void f3(){ 81 Long startTime = System.currentTimeMillis(); 82 ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10); 83 //這是一個長度爲1000的集合 84 List<Long> sourceList = new ArrayList<>(); 85 for (long i = 0L; i < 1000L; i++) { 86 sourceList.add(i); 87 } 88 System.out.println("原列表大小:" + sourceList.size()); 89 List<Long> resultList = new CopyOnWriteArrayList<>(); 90 for (Long x : sourceList) { 91 fixedThreadPool.execute(new Runnable() { 92 @Override 93 public void run() { 94 //對原列表進行處理 95 //模擬耗時操做(x累加300萬次) 96 Long sum = 0L; 97 for (long i = 0L; i < 3000000L; i++) { 98 sum += x; 99 } 100 resultList.add(sum); 101 } 102 }); 103 } 104 fixedThreadPool.shutdown();//關閉線程池 105 //此處不能夠刪除或註釋,須要線程執行結束後再執行別的內容,即只有線程結束後纔會繼續向下執行 106 while (!fixedThreadPool.isTerminated()) { 107 } 108 System.out.println("處理後的列表大小:" + resultList.size()); 109 System.out.println("耗時:" + (System.currentTimeMillis() - startTime) + "ms"); 110 } 111 112 /** 113 * 多線程版本,線程安全,Collections.synchronizedList方式 114 */ 115 static void f4(){ 116 Long startTime = System.currentTimeMillis(); 117 ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10); 118 //這是一個長度爲1000的集合 119 List<Long> sourceList = new ArrayList<>(); 120 for (long i = 0L; i < 1000L; i++) { 121 sourceList.add(i); 122 } 123 System.out.println("原列表大小:" + sourceList.size()); 124 List<Long> resultList = Collections.synchronizedList(new ArrayList<>()); 125 for (Long x : sourceList) { 126 fixedThreadPool.execute(new Runnable() { 127 @Override 128 public void run() { 129 //對原列表進行處理 130 //模擬耗時操做(x累加300萬次) 131 Long sum = 0L; 132 for (long i = 0L; i < 3000000L; i++) { 133 sum += x; 134 } 135 resultList.add(sum); 136 } 137 }); 138 } 139 fixedThreadPool.shutdown();//關閉線程池 140 //此處不能夠刪除或註釋,須要線程執行結束後再執行別的內容,即只有線程結束後纔會繼續向下執行 141 while (!fixedThreadPool.isTerminated()) { 142 } 143 System.out.println("處理後的列表大小:" + resultList.size()); 144 System.out.println("耗時:" + (System.currentTimeMillis() - startTime) + "ms"); 145 } 146 147 public static void main(String[] args) { 148 /*f1();*/ 149 /*f2();*/ 150 /*f3();*/ 151 f4(); 152 } 153 }