Java多線程中Lock鎖的使用小結
Lock基本使用
Lock它是java.util.concurrent.locks下的一個接口,它也是用來處理線程同步問題的。
public interface Lock {
void lock();
void lockInterruptibly() throws InterruptedException;
boolean tryLock();
boolean tryLock(long time, TimeUnit unit) throws InterruptedException;
void unlock();
Condition newCondition();
}- lock()獲取鎖,如果鎖不可用,則當前線程將被禁用以用于線程調度目的并處于休眠狀態(tài),直到獲得鎖為止。
- lockInterruptibly()除非當前線程被中斷,否則獲取鎖。如果可用,則獲取鎖并立即返回。如果鎖不可用,則當前線程將被禁用以用于線程調度目的并處于休眠狀態(tài),直到鎖被當前線程獲取或者其它線程中斷當前線程。
- tryLock()這種用法確保鎖在獲得時解鎖,并且在未獲得鎖時不嘗試解鎖。返回布爾類型(true/false)。
- tryLock(long time, TimeUnit unit)如果在給定的等待時間內空閑并且當前線程沒有被中斷,則獲取鎖,如果鎖可用,則此方法立即返回值true 。如果鎖不可用,則當前線程將被禁用以用于線程調度目的并處于休眠狀態(tài),直到當前線程獲取鎖,或被中斷,或指定的等待時間已到。
- unlock()釋放鎖。
- newCondition()返回綁定到此Lock實例的新Condition實例。
因為它只是接口,所以我們需要找到它的實現(xiàn)類,下面重點給大家介紹ReentrantLock,它也是我們工作中常用的
ReentrantLock
它是一種可重入互斥Lock ,其基本行為和語義與使用synchronized方法和語句訪問的隱式監(jiān)視器鎖相同,但具有擴展功能。
說了這么多,還沒帶大家體驗一把,下面我們就是來個例子試一下。
public class LockTest {
private static Lock lock = new ReentrantLock();
private static int count = 0;
private static void add() {
try {
//加鎖
lock.lock();
count++;
//重入鎖
reduce();
} finally {
// 記得釋放鎖
lock.unlock();
System.out.println(count);
}
}
private static void reduce(){
// 加鎖
lock.lock();
count--;
// 釋放鎖
lock.unlock();
}
public static void main(String[] args) throws InterruptedException {
for (int i = 0; i < 100; i++) {
new Thread(LockTest::add).start();
}
}
}我們發(fā)現(xiàn)無論執(zhí)行多少次結果都是和預期的一樣,都是0,我們再看下tryLock,直接改寫reduce:
private static void reduce1(){
if(lock.tryLock()) {
try {
count--;
}finally {
// 釋放鎖
lock.unlock();
}
}else {
System.out.println("no");
}
}通過上面的使用,我們來和Synchronized做一個對比。
- 表面上一個是關鍵字,一個是類。
- 使用上,Synchronized隱式,而Lock需要顯示,對代碼要求比較高,如果忘了釋放鎖可能會導致死鎖。
- Lock提供了tryLock方法,使得程序更加靈活。
- 代碼表現(xiàn)上Lock更加的靈活,可以在不同的方法中執(zhí)行。
結束語
本節(jié)主要講了它的基本使用,大家可以舉一反三,試試什么條件下會導致死鎖。
到此這篇關于Java多線程中Lock鎖的使用小結的文章就介紹到這了,更多相關java lock鎖使用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
關于阿里巴巴TransmittableThreadLocal使用解讀
文章主要介紹了三種ThreadLocal的使用:ThreadLocal、InheritableThreadLocal和TransmittableThreadLocal,ThreadLocal和InheritableThreadLocal在單線程和部分情況下可以正常工作,但TransmittableThreadLocal在處理線程池時表現(xiàn)更佳2025-02-02
詳解Springboot @Cacheable 注解(指定緩存位置)
這篇文章主要介紹了詳解Springboot @Cacheable 注解(指定緩存位置),使用? @Cacheable ?注解就可以將運行結果緩存,以后查詢相同的數(shù)據(jù),直接從緩存中取,不需要調用方法,需要的朋友可以參考下2023-09-09
postman中POST請求時參數(shù)包含參數(shù)list設置方式
這篇文章主要介紹了postman中POST請求時參數(shù)包含參數(shù)list設置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05
java并發(fā)編程專題(六)----淺析(JUC)Semaphore
這篇文章主要介紹了java JUC)Semaphore的相關資料,文中示例代碼非常詳細,供大家參考和學習,感興趣的朋友可以了解下2020-07-07
SSM框架整合之Spring+SpringMVC+MyBatis實踐步驟
大家都知道Spring是一個輕量級的控制反轉(IoC)和面向切面(AOP)的容器框架,本文主要介紹三大框架的整合包含spring和mybatis的配置文件,還有spring-mvc的配置文件的詳細介紹,通過項目實踐步驟給大家詳細介紹,感興趣的朋友一起看看吧2021-06-06
struts2的國際化實現(xiàn)網(wǎng)站整體中英文切換實例代碼
本篇文章主要介紹了struts2的國際化實現(xiàn)網(wǎng)站整體中英文切換實例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10

