JUC是什么
JUC是 在Java 5.0添加的 java.util.concurrent包的簡稱,目的就是為了更好的支持高並發任務,
讓開發者利用這個包進行的多線程編程時可以有效的減少競爭條件和死鎖線程。
JUC的結構
1,tools(工具類):又叫信號量三組工具類,包含有
1)CountDownLatch(閉鎖) 是一個同步輔助類,在完成一組正在其他線程中執行的操作之前,它允許一個或多個線程一直等待
2)CyclicBarrier(柵欄) 之所以叫barrier,是因為是一個同步輔助類,允許一組線程互相等待,直到到達某個公共屏障點 ,並且在釋放等待線程后可以重用。
3)Semaphore(信號量) 是一個計數信號量,它的本質是一個“共享鎖“。信號量維護了一個信號量許可集。線程可以通過調用 acquire()來獲取信號量的許可;當信號量中有可用的許可時,線程能獲取該許可;否則線程必須等待,直到有可用的許可為止。 線程可以通過release()來釋放它所持有的信號量許可。
2,executor(執行者):是Java里面線程池的頂級接口,但它只是一個執行線程的工具,真正的線程池接口是ExecutorService,里面包含的類有:
1)ScheduledExecutorService 解決那些需要任務重復執行的問題
2)ScheduledThreadPoolExecutor 周期性任務調度的類實現
3,atomic(原子性包):是JDK提供的一組原子操作類,
包含有AtomicBoolean、AtomicInteger、AtomicIntegerArray等原子變量類,他們的實現原理大多是持有它們各自的對應的類型變量value
,而且被
volatile
關鍵字修飾了。這樣來保證每次一個線程要使用它都會拿到最新的值。
4,locks(鎖包):是JDK提供的鎖機制,相比synchronized關鍵字來進行同步鎖,功能更加強大,它為鎖提供了一個框架,該框架允許更靈活地使用鎖包含的實現類有:
1)ReentrantLock 它是獨占鎖,是指只能被獨自占領,即同一個時間點只能被一個線程鎖獲取到的鎖。
2)ReentrantReadWriteLock 它包括子類ReadLock和WriteLock。ReadLock是共享鎖,而WriteLock是獨占鎖。
3)LockSupport 它具備阻塞線程和解除阻塞線程的功能,並且不會引發死鎖。
5,collections(集合類):主要是提供線程安全的集合, 比如:
1)ArrayList對應的高並發類是CopyOnWriteArrayList,
2)HashSet對應的高並發類是 CopyOnWriteArraySet,
3)HashMap對應的高並發類是ConcurrentHashMap等等