下載本文檔
版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Golangmap線(xiàn)程安全實(shí)現(xiàn)及sync.map使?及原理解析。?章?錄前?眾所周知,Golang的map是不安全的,所以sync包提供了線(xiàn)程安全的map。接下來(lái)就是把我對(duì)sync.map的理解寫(xiě)出來(lái)分享給各位。?、為什么map線(xiàn)程不安全?map不是線(xiàn)程安全的。在同?時(shí)間段內(nèi),讓不同goroutine中的代碼,對(duì)同?個(gè)字典進(jìn)行讀寫(xiě)操作是不安全的。字典值本?可能會(huì)因這些操作?產(chǎn)?混亂,相關(guān)的程序也可能會(huì)因此發(fā)?不可預(yù)知的問(wèn)題。?、配合(鎖)實(shí)現(xiàn)線(xiàn)程安全的map。1.悲觀鎖的形式悲觀鎖:進(jìn)來(lái)的每?步操作都認(rèn)為同時(shí)會(huì)有其他進(jìn)程影響操作,所以提前加鎖。lock.Lock()//map的增刪改查操作lock.UnLock()2.樂(lè)觀鎖的形式樂(lè)觀鎖:因?yàn)閙ap線(xiàn)程不安全是同時(shí):讀&&寫(xiě)||寫(xiě)&&寫(xiě)造成的,所以在map寫(xiě)的時(shí)候加上鎖就會(huì)提?map的性能。//查lock.Lock()//map的增刪改操作lock.UnLock()3.根據(jù)map實(shí)現(xiàn)原理,對(duì)?范圍進(jìn)?加鎖。另?種設(shè)想是在buckets層?或者map更基本的組成層?加鎖,根據(jù)樂(lè)觀鎖的情況進(jìn)??范圍加鎖。這?推薦?篇?佬的?章,寫(xiě)的?常好。()三、sync.map實(shí)現(xiàn)的原理。1、sync.Map的實(shí)現(xiàn)原理可概括為:a、過(guò)read和dirty兩個(gè)字段將讀寫(xiě)分離,讀的數(shù)據(jù)存在只讀字段read上,將最新寫(xiě)?的數(shù)據(jù)則存在dirty字段上b、讀取時(shí)會(huì)先查詢(xún)r(jià)ead,不存在再查詢(xún)dirty,寫(xiě)?時(shí)則只寫(xiě)?dirtyc、讀取read并不需要加鎖,?讀或?qū)慸irty都需要加鎖d、另外有misses字段來(lái)統(tǒng)計(jì)read被穿透的次數(shù)(被穿透指需要讀dirty的情況),超過(guò)?定次數(shù)則將dirty數(shù)據(jù)同步到read上e、對(duì)于刪除數(shù)據(jù)則直接通過(guò)標(biāo)記來(lái)延遲刪除2、sync.Map使??法:varmasync.Map//該類(lèi)型是開(kāi)箱即?,只需要聲明既可ma.Store("key","value")//存儲(chǔ)值ma.Delete("key")//刪除值ma.LoadOrStore("key","value")//獲取值,如果沒(méi)有則存儲(chǔ)fmt.Println(ma.Load("key"))//獲取值//遍歷ma.Range(func(key,valueinterface{})bool{fmt.Printf("key:%s,value:%s\n",key,value)//false,則退出循環(huán),如果返回:returntrue})總結(jié)map底層雖然寫(xiě)的尤為漂亮,但是為了效率,沒(méi)有把線(xiàn)程安全安排上,所以另外加了sync.map,兼容線(xiàn)程安全。在我的理解中,sync.map實(shí)現(xiàn)就是依靠?jī)蓮坢ap對(duì)讀操作和寫(xiě)操作分離,后續(xù)根據(jù)需要在把dirty
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024正規(guī)個(gè)人基金份額購(gòu)買(mǎi)合同范本3篇
- 二零二四年度建筑設(shè)計(jì)委托合同范本
- 2024攤位轉(zhuǎn)讓合同范本
- 2025年度城市應(yīng)急響應(yīng)安保支援協(xié)議3篇
- 2024年餐飲服務(wù)協(xié)議:快餐店顧客權(quán)益保障
- 2025年度綠色環(huán)保型廁所改造施工合同范本3篇
- 長(zhǎng)沙學(xué)院《影視攝影技術(shù)》2023-2024學(xué)年第一學(xué)期期末試卷
- 2適用于不同行業(yè)的2024年版承包合同
- 教育教學(xué)行業(yè)教學(xué)理念培訓(xùn)實(shí)踐
- 青春奮進(jìn)社團(tuán)助力實(shí)現(xiàn)夢(mèng)想計(jì)劃
- 2025年急診科護(hù)理工作計(jì)劃
- 高中家長(zhǎng)會(huì) 高二寒假線(xiàn)上家長(zhǎng)會(huì)課件
- 2024-2025學(xué)年山東省聊城市高一上學(xué)期期末數(shù)學(xué)教學(xué)質(zhì)量檢測(cè)試題(附解析)
- 違規(guī)行為與處罰管理制度
- 2025年正規(guī)的離婚協(xié)議書(shū)
- 個(gè)人教師述職報(bào)告錦集10篇
- 四川省等八省2025年普通高中學(xué)業(yè)水平選擇性考試適應(yīng)性演練歷史試題(含答案)
- 2025中國(guó)地震應(yīng)急搜救中心公開(kāi)招聘應(yīng)屆畢業(yè)生5人高頻重點(diǎn)提升(共500題)附帶答案詳解
- 醫(yī)療健康大模型白皮書(shū)(1.0版) 202412
- 部編版八年級(jí)初二語(yǔ)文上冊(cè)第六單元《寫(xiě)作表達(dá)要得體》說(shuō)課稿
- 《內(nèi)部培訓(xùn)師培訓(xùn)》課件
評(píng)論
0/150
提交評(píng)論