java公平索非公平鎖_java中的非公平鎖不怕有的線程一直得不到執行嗎

首先來看公平鎖和非公平鎖,我們默認使用的鎖是非公平鎖,只有當我們顯示設置為公平鎖的情況下,才會使用公平鎖,下面我們簡單看一下公平鎖的源碼,如果等待隊列中沒有節點在等待,則占有鎖,如果已經存在等待節點,則返回失敗,由后面的程序去將此線程加入等待隊列

4137e813b2532f0c0218eb7cef855301.png

通過上面的代碼,我們可以推斷,當使用公平鎖的情況下,并且同一個線程的執行時間較長時,線程內部進行了多次的鎖的獲取和釋放,效率非常低下,可以參加Lesson8中的demo:

demo Lesson8LockIntPerform:在使用ReentrantLock加非公平鎖的情況下100個線程循環下單數為:857239882

demo Lesson8LockIntPerform:在使用ReentrantLock加非公平鎖的情況下100個線程循環下單數為:860364303

demo Lesson8LockFairIntPerform:在使用ReentrantLock加公平鎖的情況下100個線程循環下單數為:19153640

demo Lesson8LockFairIntPerform:在使用ReentrantLock加公平鎖的情況下100個線程循環下單數為:19076567

上面的demo中,在使用公平鎖的情況下性能明顯降低,非公平鎖的性能是公平鎖性能的幾十倍以上,這和公平鎖每次試圖占有鎖時,都必須先要進等待隊列,按照FIFO的順序去獲取鎖,因此在我們的實驗情景下,使用公平鎖的線程進行了頻繁切換,而頻繁切換線程,性能必然會下降的厲害,這也告誡了我們在實際的開發過程中,在需要使用公平鎖的情景下,務必要考慮線程的切換頻率。

接下來我們來看一下讀寫鎖,通過看讀寫鎖的實現源碼,我們可以發現,讀鎖和寫鎖共用同一個等待隊列,那么在采用非公平鎖的情況下,如果讀鎖的線程執行時間比較長,并且讀鎖的并發比較高,那么寫鎖的線程便永遠都拿不到鎖,那么實際的情況會不會是這樣呢?

demo?Lesson3WriteReadLock:此demo的讀線程在不斷的占用讀鎖,按照推論,寫鎖的線程是沒有機會獲取到鎖的,但是實際情況是寫鎖的線程可以正常的獲取到鎖,那么是什么原因使得寫鎖的線程可以獲取到鎖的了?通過查看源代碼,會發現有這樣的一個方法:

90aab2e7a78349df2d47a64f5c6872eb.png

上面的方法,實現了一個新的讀線程獲取鎖的中斷,它會讀取等待隊列中下一個等待鎖的線程,如果它是獲取寫鎖的線程,那么此方法返回為真,調用它的程序會把這個試圖獲取讀鎖的線程加入到等待隊列,從而終止了讀線程一直都在占有鎖的情況。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/378646.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/378646.shtml
英文地址,請注明出處:http://en.pswp.cn/news/378646.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mybatis.net - 5 嵌入資源與引用資源

在SqlMap.config文件中可以有兩種方式引入外部的文件。 一種是通過資源的方式&#xff0c;在文件中表現為 resource&#xff0c;就是引用外部的文件&#xff0c;這里需要保證文件的路徑正確。 <sqlMaps><sqlMap resource"Maps/ProductMap.xml"/><sqlM…

智能車復工日記【3】:圖像處理——基本掃線和基本特征提取和十字補線

博主聯系方式: QQ:1540984562 QQ交流群:892023501 群里會有往屆的smarters和電賽選手,群里也會不時分享一些有用的資料,有問題可以在群里多問問。 目錄 1、系列文章2、前言3、基本掃線(除了進入環島狀態或者坡道或者十字路口的普通掃線)1.基本數據和初步特征4、進一步特征…

short 用equals_Java Short類equals()方法的示例

short 用equals短類equals()方法 (Short class equals() method) equals() method is available in java.lang package. equals()方法在java.lang包中可用。 equals() method is used to check equality or inequality of this Object against the given Object or in other wo…

圖解MySQL數據庫的陳列和把持-4

泉源&#xff1a;網海拾貝 填入一些測試數據&#xff1a; 封閉“MySQL Query Browser”&#xff0c;再從頭翻開它&#xff0c;切換到testtable表&#xff0c;看到了沒有&#xff1f;剛剛輸出的中文變成了“&#xff1f;&#xff1f;&#xff1f;&#xff1f;&#xff1f;&am…

非常好友(C++)

Bessie和其他的所有奶牛的耳朵上都戴有一個射頻識別&#xff08;RFID&#xff09;序列號碼牌。因此農夫John可以機械化地計算他們的數量。很多奶牛都有一個“牛友”。如果奶牛A的序列號的約數之和剛好等于奶牛B的序列號&#xff0c;那么A的牛友就是B。在這里&#xff0c;一個數…

智能車復工日記【2】——普通PID、變結構PID、微分先行PID、模糊PID、專家PID

博主聯系方式: QQ:1540984562 QQ交流群:892023501 群里會有往屆的smarters和電賽選手,群里也會不時分享一些有用的資料,有問題可以在群里多問問。 目錄 系列文章前言普通PID舵機參數:電機參數:變結構PI控制(電機控制,這里對公式進行修改采用正態分布公式)微分先行PID(…

爬動的蠕蟲(C++)

問題描述&#xff1a; 一條蟲子在n英寸深的井底&#xff0c;每次一分鐘爬行u英寸&#xff0c;但是它再次爬行前必須先休息1分鐘&#xff0c;在休息過程中它將滑落d英寸&#xff0c;在反復向上爬行和休息后&#xff0c;多長時間蟲子能爬出這口井&#xff1f;在此過程中&#xf…

使用快捷鍵,快到極致

前段時間曾經寫過一篇文章&#xff0c;《優秀程序員無他-善假于物也》。其中談到一點是優秀的程序員必須要能靈活的掌握常用軟件的快捷鍵。對于程序員來說&#xff0c;每天使用時間最長的軟件恐怕就是IDE&#xff08;Integrated Development Environment&#xff09;了。如果你…

java反射對象賦值_Java反射詳解

反射(Reflection)能夠讓運行于 JVM 中的程序檢測和修改運行時的行為。Class類提供了以下方法四個public方法&#xff0c;用于獲取某個類的構造方法&#xff1a;Constructor getConstructor(Class[] params)// 根據構造函數的參數&#xff0c;返回一個具體的具有public屬性的構造…

Oracle裝置后果

來歷&#xff1a;網海拾貝 本日未來誥日裝置Oracle后&#xff0c;出現了兩個后果。 經過過程SQL Plus不竭無法連接長途數據庫&#xff0c;提醒錯誤ORA-12514:TNS:監聽過程不能解析在連接描繪符中給出的SERVICE_NAME。 厥后締造用可視化的Net Configuration Assistant東西對監聽…

Java Hashtable hashCode()方法及示例

Hashtable類hashCode()方法 (Hashtable Class hashCode() method) hashCode() method is available in java.util package. hashCode()方法在java.util包中可用。 hashCode() method is used to return the hash code value for this object in this Hashtable. hashCode()方法…

C---蟬、蜻蜓、蜘蛛

【問題描述】 已知 腿/條翅膀/對蟬61蜻蜓62蜘蛛80 現有小蟲n只&#xff0c;共有X條腿和Y對翅膀&#xff0c;問蟬、蜻蜓、蜘蛛各有多少只&#xff1f;請使用循環的知識解決&#xff0c;數據確保有解。 【輸入形式】三個用空格隔開的整數&#xff0c;依次為n、X、Y 【輸出形式】…

輪廓(查找和繪制輪廓、輪廓的表達與組織、輪廓的特性)

目錄1、輪廓的定義2、如何在圖像中找到輪廓opencv自帶的查找輪廓函數:findContours()3、輪廓的表達方式1.頂點的序列2.Freeman鏈碼4、輪廓之間的組織方式5、輪廓的特點&#xff08;這部分可以展開來詳細探討&#xff0c;這里不做過多解釋&#xff09;6、輪廓的匹配7、繪制輪廓d…

python如何操作oracle數據庫_python操作oracle數據庫

搜索熱詞下面是編程之家 jb51.cc 通過網絡收集整理的代碼片段。編程之家小編現在分享給大家&#xff0c;也給大家做個參考。# -*- mode: python; coding: utf-8 -*-## python operate oracle,contain insert、delete、update、select.## author liyulin# date 2014-11-07import…

可能用得上的jquery 插件

Chosen (github) 是一個強大的增強下拉選擇框的插件&#xff0c;支持自定義css樣式。同時你可以使用ajax增加一些回調函數&#xff0c;插件會給hidden input復制&#xff0c;這樣你可以在提交表單的時候獲得正確的值。 Turn.js 是一個 JavaScript 庫&#xff0c;使您的網頁內容…

草根創業回憶錄二: 都選擇的是什么人?

草根創業回憶錄二: 都選擇的是什么人&#xff1f; 前言&#xff1a;選合伙人和投資就像在選女朋友一樣&#xff0c;要謹慎&#xff0c;甚至有時候寧缺毋濫。 曾經以為有了錢&#xff0c;就會找到需要的人&#xff0c;后來發現不是這樣的。 也以為&#xff0c;隨便拉幾個關系好的…

float.equals_Java Float類equals()方法與示例

float.equals浮動類equals()方法 (Float class equals() method) equals() method is available in java.lang package. equals()方法在java.lang包中可用。 equals() method is used to check equality or inequality of this Object against the given Object or in other wo…

01-基本配置與測試

一、開發環境 使用的是Anaconda 3&#xff0c;其中Python版本為3.6.3 首先&#xff0c;在Anaconda下的Scripts文件夾下打開命令框 使用pip install -U selenium安裝selenium 打開Jupiter Notebook&#xff0c;輸入from selenium import webdriver進行測試 不報錯即安裝成功 …

Opencv——查找并繪制凸包、凸包與輪廓的關系

定義 給定二維平面上的點集&#xff0c;凸包就是將最外層的點連接起來構成的凸多邊型。 理解物體形狀或輪廓的一 種比較有用的方法便是計算一個物體的凸包&#xff0c;然后計算其凸缺陷(convexity defects)。 檢測凸包 opencv自帶函數&#xff1a;convexHull() 參數解釋&a…

EF Code First 簡單的示例

一對多&#xff1a; public class Category {public Category(){Id GuidComb.GenerateComb();}public Guid Id { get; set; }public string Name { get; set; }public string Description { get; set; }public virtual IList<Topic> Topics { get; set; } }public class…