亚欧洲精品在线观看,窝窝影院午夜看片,久久国产成人午夜av影院宅,午夜91,免费国产人成网站,ts在线视频,欧美激情在线一区

java語言

Java中同步與并發(fā)的運用

時間:2025-02-06 18:57:19 java語言 我要投稿
  • 相關推薦

Java中同步與并發(fā)的運用

  Java中同步與并發(fā)的運用

  1.同步容器類包括兩部分:vector和hashtable

  另一類是同步包裝類,由Collections.synchronizedXXX創(chuàng)建。同步容器對容器的所有狀態(tài)進行串行訪問,從而實現線程安全。

  它們存在如下問題:

  a) 對于符合操作,需要額外的鎖保護。比如迭代,缺少則添加等條件運算。

  b) toString,hashCode,equals都會間接的調用迭代,都需要注意并發(fā)。

  2.java5.0中的.并發(fā)容器。

  ConcurrentHashMap可以替代同步Map實現。

  當主要為讀操作時,CopyOnWriteArrayList是List的同步實現。

  同時,增加了Queue和BlockingQueue:ConcurentLinkedQueue:FIFO隊列。

  PriorityQueue:非并發(fā)的優(yōu)先級順序隊列。

  BlockingQueue則增加了可阻塞的插入和獲取。

  a) ConcurentHashMap:不是使用一個公共鎖,而是分離鎖。任意數量的讀線程可以并發(fā)訪問map,讀者和寫者也可以并發(fā)訪問Map,并且有限數量的寫還可以并發(fā)修改Map。但是,size和isEmpty語言被弱化,是估算值。

  b) CopyOnWriteArrayList:迭代器保留一個底層基礎數組引用,改引用不會修改。

  3.Synchronizer

  a) 閉鎖(CountDownLatch)。構造函數參數為n,通過countDown,n為0后,所有await的線程繼續(xù)執(zhí)行。

  b) FutureTask:計算由Callable實現,可以攜帶結果的Runnable。包括:等待,運行和完成。

  c) Semaphore:控制能夠同時訪問的活動數量

  d) CyclicBarrier:類似于閉鎖。閉鎖等待的是事件,關卡等待的是其他線程。初始n,Runnable r,n個線程都await(),當n個線程都執(zhí)行完成后到達關卡時,r執(zhí)行,關卡重置,n個線程繼續(xù)。

 

【Java中同步與并發(fā)的運用】相關文章:

java并發(fā)編程參考12-01

Java線程同步的方法05-27

Java并發(fā)編程:深入剖析ThreadLocal03-15

Java 如何進行線程同步05-19

java多線程的同步和異步02-02

從 JDK 源碼角度看 java 并發(fā)線程的中斷03-09

Java的設計模式編程中責任鏈模式的運用的實例講解07-07

JAVA多線程并發(fā)下的單例模式應用02-22

Java線程同步的優(yōu)先級介紹04-10