java - 讀寫鎖中 寫鎖的降級問題
問題描述
寫鎖降級的時候 要求當前已經獲取到寫鎖的線程把持住寫鎖,然后獲取讀鎖,隨后釋放寫鎖。
那么為什么要求把持住寫鎖呢??
上圖中提到 “ 那么當前線程無法感知線程T的數據更新 ” 這個如何理解。如果線程T獲取到了寫鎖,然后對數據進行了更新,在沒有釋放寫鎖之前,當前線程無法感知到數據的更新,這個是沒問題的吧,但是一旦線程T釋放 寫鎖,那么當前線程就可以感知到數據的更新了,這里理解應該沒問題吧?
help me to explain,thx
問題解答
回答1:這是在解釋鎖降級吧,首先寫鎖是獨占的,讀鎖是共享的,然后讀寫鎖是線程間互斥的,鎖降級的前提是所有線程都希望對數據變化敏感,但是因為寫鎖只有一個,所以會發生降級。如果先釋放寫鎖,再獲取讀鎖,可能在獲取之前,會有其他線程獲取到寫鎖,阻塞讀鎖的獲取,就無法感知數據變化了。所以需要先hold住寫鎖,保證數據無變化,獲取讀鎖,然后再釋放寫鎖。
回答2:寫鎖不允許其他進程的讀寫操作,讀鎖的允許讀操作。就按你抓圖的例子來看,當你釋放寫鎖后,T進程獲取了寫鎖,這時你就無法獲取讀鎖了,所以要先獲取讀鎖后,再釋放寫鎖。
首先你沒理解讀寫鎖的意義,讀鎖的存在意味著不允許其他寫操作的存在。按照你提供的例子,可能存在一個事務線程不希望自己的操作被別的線程中斷,而這個事務操作可能分成多部分操作更新不同的數據(或表)甚至非常耗時。如果長時間用寫鎖獨占,顯然對于某些高響應的應用是不允許的,所以在完成部分寫操作后,退而使用讀鎖降級,來允許響應其他進程的讀操作。只有當全部事務完成后才真正釋放鎖。按你的理解如果當中寫鎖被其他線程占用,那么這個事務線程將不得不中斷等待別的寫鎖釋放。
回答3:“ 那么當前線程無法感知線程T的數據更新 ”
T1 讀取 數據 Data時,將數據值復制到當前線程的上下文,因此其他線程沒有辦法感知數據是否更新。只要當數據提交內存中,即Heap中,其他線程才可以得到最新值。
相關文章:
1. sql語句 - 如何在mysql中批量添加用戶?2. php - 數據庫表如果是null怎么替換為其他字段的值3. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。4. javascript - mysql插入數據時怎樣避免與庫中的數據重復?5. mysql - JAVA怎么實現一個DAO同時實現查詢兩個實體類的結果集6. shell - Update query wrong in MySQL7. 事務 - mysql共享鎖lock in share mode的實際使用場景8. mysql - 數據庫建字段,默認值空和empty string有什么區別 1109. mysql - PHP定時通知、按時發布怎么做?10. mysql建表報錯,查手冊看不懂,求解?
