原文:各類鎖(互斥鎖,自旋鎖,讀寫鎖,樂觀鎖,悲觀鎖,死鎖)

互斥鎖 當有一個線程要訪問共享資源 臨界資源 之前會對線程訪問的這段代碼 臨界區 進行加鎖。如果在加鎖之后沒釋放鎖之前其他線程要對臨界資源進行訪問,則這些線程會被阻塞睡眠,直到解鎖,如果解鎖時有一個或者多個線程阻塞,那么這些鎖上的線程就會變成就緒狀態,然后第一個變為就緒狀態的線程就會獲取資源的使用權,並且再次加鎖,其他線程繼續阻塞等待。 讀寫鎖 也叫做共享互斥鎖,讀模式共享,寫模式互斥。有點像數據 ...

2019-11-27 10:01 0 780 推薦指數:

查看詳情

面試官:你說說互斥自旋讀寫鎖悲觀樂觀的應用場景

前言 生活中用到的,用途都比較簡單粗暴,上鎖基本是為了防止外人進來、電動車被偷等等。 但生活中也不是沒有 BUG 的,比如加鎖的電動車在「廣西 - 竊·格瓦拉」面前,就是形同虛設,只要他願意,他就可以輕輕松松地把你電動車給「順走」,不然打工怎么會是他這輩子不可能的事情呢?牛逼之人,必有牛逼 ...

Thu Oct 22 22:12:00 CST 2020 1 502
面試官:你說說互斥自旋讀寫鎖悲觀樂觀的應用場景

前言 生活中用到的,用途都比較簡單粗暴,上鎖基本是為了防止外人進來、電動車被偷等等。 但生活中也不是沒有 BUG 的,比如加鎖的電動車在「廣西 - 竊·格瓦拉」面前,就是形同虛設,只要他願意,他就可以輕輕松松地把你電動車給「順走」,不然打工怎么會是他這輩子不可能的事情 ...

Wed Sep 16 04:15:00 CST 2020 4 5901
互斥、遞歸讀寫鎖自旋區別

互斥 共享資源的使用是互斥的,即一個線程獲得資源的使用權后就會將改資源加鎖,使用完后會將其解鎖,所以在使用過程中有其它線程想要獲取該資源的,那么它就會被阻塞陷入睡眠狀態,直到該資源被解鎖才會別喚醒,如果被阻塞的資源不止一個,那么它們都會被喚醒,但是獲得資源使用權的是第一個被喚醒的線程 ...

Tue Aug 06 23:19:00 CST 2019 0 1387
Linux 自旋互斥量(互斥),讀寫鎖

自旋(Spin Lock) 自旋類似於互斥量,不過自旋不是通過休眠阻塞進程,而是在取得之前一直處於忙等待的阻塞狀態。這個忙等的阻塞狀態,也叫做自旋自旋通常作為底層原語實現其他類型的。 適用場景: 1)被持有的時間短,而且線程不希望在重新調度上花費太多的成本; 2)在非搶占 ...

Wed Sep 01 02:55:00 CST 2021 0 117
 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM