這篇“Java JUC怎么操作List安全類的集合”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Java JUC怎么操作List安全類的集合”文章吧。
創(chuàng)新互聯(lián)公司網(wǎng)站建設由有經(jīng)驗的網(wǎng)站設計師、開發(fā)人員和項目經(jīng)理組成的專業(yè)建站團隊,負責網(wǎng)站視覺設計、用戶體驗優(yōu)化、交互設計和前端開發(fā)等方面的工作,以確保網(wǎng)站外觀精美、成都網(wǎng)站制作、成都網(wǎng)站設計易于使用并且具有良好的響應性。
在單線程應用中,通常采取new ArrayList(),指定一個List集合,用于存放可重復的數(shù)據(jù)。
但在多線程下,往往會出現(xiàn)意想不到的問題,代碼如下所示:
import java.util.*; public class ListTest { public static void main(String[] args) throws InterruptedException { // 創(chuàng)建list集合 //List<String> lists = Arrays.asList("1", "2", "3"); // 不安全 List<String> lists = new ArrayList<>(); // 開啟十個線程增加數(shù)據(jù) for (int i = 1; i <= 40; i++) { new Thread(()->{ lists.add(UUID.randomUUID().toString().substring(0,5)); System.out.println(Thread.currentThread().getName()+"=="+lists); },String.valueOf(i)).start(); } } }
多線程操作同一集合對象信息,往往會出現(xiàn)java.util.ConcurrentModificationException異常報錯信息。
在java語言中,提供了一種新的List集合,java.util.Vector類,具體看下列代碼:
import java.util.*; public class ListTest { public static void main(String[] args) throws InterruptedException { // 創(chuàng)建list集合 //List<String> lists = Arrays.asList("1", "2", "3"); // 不安全 //List<String> lists = new ArrayList<>(); List<String> lists = new Vector<>(); // 開啟十個線程增加數(shù)據(jù) for (int i = 1; i <= 40; i++) { new Thread(()->{ lists.add(UUID.randomUUID().toString().substring(0,5)); System.out.println(Thread.currentThread().getName()+"=="+lists); },String.valueOf(i)).start(); } } }
不會出現(xiàn)java.util.ConcurrentModificationException報錯信息。
為什么能保證數(shù)據(jù)的安全操作?
采取了 synchronized 針對方法執(zhí)行調(diào)用者加鎖,保證add操作的多線程安全性!
在JUC包下,提供有以下幾種創(chuàng)建安全集合的方式。
方式一:Collections.synchronizedList(new ArrayList<>());
import java.util.*; public class ListTest { public static void main(String[] args) throws InterruptedException { List<String> lists = Collections.synchronizedList(new ArrayList<>()); // 開啟十個線程增加數(shù)據(jù) for (int i = 1; i <= 40; i++) { new Thread(()->{ lists.add(UUID.randomUUID().toString().substring(0,5)); System.out.println(Thread.currentThread().getName()+"=="+lists); },String.valueOf(i)).start(); } } }
查看底層源碼實現(xiàn)邏輯
判斷傳入的 list 集合類型,判斷類型是否為 java.util.RandomAccess,如果是則采取java.util.Collections.SynchronizedRandomAccessList構(gòu)造集合,如果不是則采取java.util.Collections.SynchronizedList構(gòu)造集合。
源碼中對應的add操作邏輯如下所示:
采取synchronized同步代碼塊的方式,對數(shù)據(jù)的add操作實現(xiàn)加鎖!
方式二:new CopyOnWriteArrayList();
import java.util.*; import java.util.concurrent.CopyOnWriteArrayList; public class ListTest { public static void main(String[] args) throws InterruptedException { List<String> lists = new CopyOnWriteArrayList<>(); // 開啟十個線程增加數(shù)據(jù) for (int i = 1; i <= 40; i++) { new Thread(()->{ lists.add(UUID.randomUUID().toString().substring(0,5)); System.out.println(Thread.currentThread().getName()+"=="+lists); },String.valueOf(i)).start(); } } }
源碼中的介紹如下:
顯而易見,其邏輯如下所示:
調(diào)用add方法后,拿到java.util.concurrent.locks.ReentrantLock對象信息。
調(diào)用 lock.lock() 拿到鎖!
將原數(shù)組對象copy操作,并創(chuàng)建原數(shù)組大小+1的新數(shù)組。
將新數(shù)據(jù)放入新數(shù)組中。
任何操作finally,都進行鎖的釋放!
JUC包下的Lock操作,都比synchronized性能更好!
以上就是關(guān)于“Java JUC怎么操作List安全類的集合”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
本文題目:JavaJUC怎么操作List安全類的集合
本文URL:http://chinadenli.net/article18/ppeegp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供面包屑導航、移動網(wǎng)站建設、網(wǎng)站建設、微信小程序、企業(yè)網(wǎng)站制作、網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)