同步機(jī)制

經(jīng)典實(shí)現(xiàn)

信號(hào)量

信號(hào)量與PV原語(yǔ)操作由Dijkstra發(fā)明云挟,也是使用最廣泛的互斥方法之一。它包含以下幾個(gè)元素:

  • Semaphore S(信號(hào)量)
  • Operation P,有時(shí)也表達(dá)為wait()
  • Operation V, 有時(shí)也表達(dá)為signal()
    Semaphore S用于指示共享資源的可用數(shù)量,P原語(yǔ)可以減小S計(jì)數(shù)逃呼,V則增加它的計(jì)數(shù)。由此可知當(dāng)某個(gè)進(jìn)程想進(jìn)入共享區(qū)者娱,首先要執(zhí)行P操作抡笼;同理,想退出共享區(qū)時(shí)執(zhí)行V操作黄鳍。


    PV操作圖

Mutex

Mutual Exclusion推姻,其釋義為互斥體。Mutex通常是對(duì)某一排他資源的共享控制——要么這個(gè)資源被占用(Lock)际起,要么就是可以訪問(wèn)(unlock)拾碌。

管程(Monitor)

管程是可以被多個(gè)線程/進(jìn)程安全訪問(wèn)的對(duì)象(Object)或者模塊(module)。管程中的方法都是受mutual exclusion保護(hù)的街望,意味著著同一時(shí)刻只允許一個(gè)訪問(wèn)者使用它們校翔。另外管程還具備如下屬性:

  • 安全性
  • 互斥性
  • 共享性

Android中的同步機(jī)制

Mutex

Android中的Mutex只是對(duì)pthread提供的API的簡(jiǎn)單再封裝,另外Mutex中還包含一個(gè)AutoLock的嵌套類灾前,它利用變量生命周期特點(diǎn)而設(shè)計(jì)的一個(gè)輔助類防症。
Mutex既可以實(shí)現(xiàn)進(jìn)程內(nèi)的永不,也可以解決進(jìn)程間同步問(wèn)題。與Semaphore不同蔫敲,Mutex只有兩種狀態(tài)饲嗽,即0和1。當(dāng)調(diào)用者希望訪問(wèn)臨界資源時(shí)奈嘿,它必須先通過(guò)lock()來(lái)獲取資源鎖貌虾。如果此時(shí)資源可用,這個(gè)函數(shù)立馬返回裙犹;否則尽狠,會(huì)進(jìn)入阻塞等待,知道有人釋放了資源鎖并喚醒它叶圃。釋放資源鎖調(diào)用unlock()袄膏,同時(shí)正在等待使用這個(gè)鎖的其他對(duì)象會(huì)被喚醒,然后繼續(xù)執(zhí)行它的任務(wù)掺冠。另外Mutex還特別提供了一個(gè)tryLock()來(lái)滿足程序多樣化需求沉馆。這個(gè)函數(shù)會(huì)試探性地查詢資源鎖是否可用,在不可用的情況下德崭,并不會(huì)阻塞斥黑,而是同樣立即返回,只是返回值不為0接癌。

Condition

Condition是“條件變量”在Android系統(tǒng)中的實(shí)現(xiàn)類心赶,它是依賴Mutex來(lái)完成的。

Barrier

Barrier是同時(shí)基于Mutex和Condition實(shí)現(xiàn)的一個(gè)模型缺猛。是對(duì)Condition的一個(gè)應(yīng)用,Barrier類是專門為SurfaceFlinger而設(shè)計(jì)的椭符。

加解鎖的自動(dòng)化操作——Autolock

在Mutex類內(nèi)部的Autolock嵌套類荔燎,實(shí)現(xiàn)了加、解鎖的自動(dòng)化操作销钝。它的實(shí)現(xiàn)原理為:
當(dāng)Autolock構(gòu)造時(shí)有咨,會(huì)主動(dòng)調(diào)用內(nèi)部成員變量mLock的lock()方法來(lái)獲取一個(gè)鎖。而在析構(gòu)時(shí)蒸健,調(diào)用它的unlock()方法釋放鎖座享。這樣假如一個(gè)Autolock對(duì)象是局部變量的話,那么它在生命周期結(jié)束時(shí)就會(huì)自動(dòng)把資源解鎖似忧。

參考資料

  • 深入理解Android內(nèi)核設(shè)計(jì)思想. 林學(xué)森渣叛。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市盯捌,隨后出現(xiàn)的幾起案子淳衙,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件箫攀,死亡現(xiàn)場(chǎng)離奇詭異肠牲,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)靴跛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門缀雳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人梢睛,你說(shuō)我怎么就攤上這事俏险。” “怎么了扬绪?”我有些...
    開(kāi)封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵竖独,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我挤牛,道長(zhǎng)莹痢,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任墓赴,我火速辦了婚禮竞膳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘诫硕。我一直安慰自己坦辟,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布章办。 她就那樣靜靜地躺著锉走,像睡著了一般。 火紅的嫁衣襯著肌膚如雪藕届。 梳的紋絲不亂的頭發(fā)上挪蹭,一...
    開(kāi)封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音休偶,去河邊找鬼梁厉。 笑死,一個(gè)胖子當(dāng)著我的面吹牛踏兜,可吹牛的內(nèi)容都是我干的词顾。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼碱妆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼肉盹!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起山橄,我...
    開(kāi)封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤垮媒,失蹤者是張志新(化名)和其女友劉穎舍悯,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體睡雇,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡萌衬,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了它抱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秕豫。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖观蓄,靈堂內(nèi)的尸體忽然破棺而出混移,到底是詐尸還是另有隱情,我是刑警寧澤侮穿,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布歌径,位于F島的核電站,受9級(jí)特大地震影響亲茅,放射性物質(zhì)發(fā)生泄漏回铛。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一克锣、第九天 我趴在偏房一處隱蔽的房頂上張望茵肃。 院中可真熱鬧,春花似錦袭祟、人聲如沸验残。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)您没。三九已至,卻和暖如春想鹰,著一層夾襖步出監(jiān)牢的瞬間紊婉,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工辑舷, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人槽片。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓何缓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親还栓。 傳聞我的和親對(duì)象是個(gè)殘疾皇子碌廓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容