這篇文章主要介紹“ReentrantLock是什么”,在日常操作中,相信很多人在ReentrantLock是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”ReentrantLock是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在鶴山等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都做網(wǎng)站、網(wǎng)站設計 網(wǎng)站設計制作按需開發(fā),公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站設計,營銷型網(wǎng)站,外貿網(wǎng)站制作,鶴山網(wǎng)站建設費用合理。
codereview的時候看到有人創(chuàng)建了一個static的reentrantLock來使用,并且只是用到了lock()、unlock(), 應該是哪里錯了吧? : (
我問了下自己:關于ReentrantLock我能說出來點兒什么?然后就去讀了讀API文檔。: )
ReentrantLock是可查詢、可定時、可中斷的鎖機制。(我還沒理解什么是無條件的。)
它解決了內置鎖(synchronized使用):不能中斷正在等待獲取鎖的線程、必須在獲得鎖的代碼塊釋放鎖這樣的問題。
1) “可查詢”是通過tryLock()完成的。對內置鎖來說,你一旦嘗試獲取鎖就會被block直到拿到這個鎖。這個阻塞方法對應到ReentrantLock的lock()方法。
2) 可定時是說,你可以給tryLock()方法傳入一個超時時間。
3) 用lockInterruptibly()方法獲取鎖時如果被block,則是可以通過線程中斷被終止的。
4) 一定不要忘記finally { unlock(); }
5) 可以通過構造參數(shù)創(chuàng)建公平鎖。
6) 只有在你真的需要:可中斷、可定時、可查詢、公平隊列、非塊結構鎖是再考慮,否則使用synchronized!
7) ReentrantLock還有一些其它getHoldCount(), getQueueLength()之類的方法,對于非并發(fā)庫開發(fā)者來說知道就好。我可能一輩子也用不上這些API。
回到code review,看來我的困惑是對的。
下面是Lock接口定義的方法:
到此,關于“ReentrantLock是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
新聞名稱:ReentrantLock是什么
網(wǎng)站路徑:http://www.chinadenli.net/article42/iejpec.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供建站公司、自適應網(wǎng)站、靜態(tài)網(wǎng)站、定制開發(fā)、ChatGPT、電子商務
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)