下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Golangmap線程安全實(shí)現(xiàn)及sync.map使?及原理解析。?章?錄前?眾所周知,Golang的map是不安全的,所以sync包提供了線程安全的map。接下來(lái)就是把我對(duì)sync.map的理解寫出來(lái)分享給各位。?、為什么map線程不安全?map不是線程安全的。在同?時(shí)間段內(nèi),讓不同goroutine中的代碼,對(duì)同?個(gè)字典進(jìn)行讀寫操作是不安全的。字典值本?可能會(huì)因這些操作?產(chǎn)?混亂,相關(guān)的程序也可能會(huì)因此發(fā)?不可預(yù)知的問題。?、配合(鎖)實(shí)現(xiàn)線程安全的map。1.悲觀鎖的形式悲觀鎖:進(jìn)來(lái)的每?步操作都認(rèn)為同時(shí)會(huì)有其他進(jìn)程影響操作,所以提前加鎖。lock.Lock()//map的增刪改查操作lock.UnLock()2.樂觀鎖的形式樂觀鎖:因?yàn)閙ap線程不安全是同時(shí):讀&&寫||寫&&寫造成的,所以在map寫的時(shí)候加上鎖就會(huì)提?map的性能。//查lock.Lock()//map的增刪改操作lock.UnLock()3.根據(jù)map實(shí)現(xiàn)原理,對(duì)?范圍進(jìn)?加鎖。另?種設(shè)想是在buckets層?或者map更基本的組成層?加鎖,根據(jù)樂觀鎖的情況進(jìn)??范圍加鎖。這?推薦?篇?佬的?章,寫的?常好。()三、sync.map實(shí)現(xiàn)的原理。1、sync.Map的實(shí)現(xiàn)原理可概括為:a、過read和dirty兩個(gè)字段將讀寫分離,讀的數(shù)據(jù)存在只讀字段read上,將最新寫?的數(shù)據(jù)則存在dirty字段上b、讀取時(shí)會(huì)先查詢r(jià)ead,不存在再查詢dirty,寫?時(shí)則只寫?dirtyc、讀取read并不需要加鎖,?讀或?qū)慸irty都需要加鎖d、另外有misses字段來(lái)統(tǒng)計(jì)read被穿透的次數(shù)(被穿透指需要讀dirty的情況),超過?定次數(shù)則將dirty數(shù)據(jù)同步到read上e、對(duì)于刪除數(shù)據(jù)則直接通過標(biāo)記來(lái)延遲刪除2、sync.Map使??法:varmasync.Map//該類型是開箱即?,只需要聲明既可ma.Store("key","value")//存儲(chǔ)值ma.Delete("key")//刪除值ma.LoadOrStore("key","value")//獲取值,如果沒有則存儲(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底層雖然寫的尤為漂亮,但是為了效率,沒有把線程安全安排上,所以另外加了sync.map,兼容線程安全。在我的理解中,sync.map實(shí)現(xiàn)就是依靠?jī)蓮坢ap對(duì)讀操作和寫操作分離,后續(xù)根據(jù)需要在把dirty
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025下半年安徽池州市貴池區(qū)事業(yè)單位招聘工作人員41人高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025下半年四川廣元?jiǎng)﹂w縣委組織部人社局考試招聘事業(yè)單位工作人員高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025下半年四川事業(yè)單位聯(lián)考招聘歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025上半年福建省寧德福安市事業(yè)單位招聘89人及歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025上半年江蘇省鹽城事業(yè)單位招聘737人歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025上半年廣東深圳市光明區(qū)事業(yè)單位招聘工作人員24人歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2025上半年四川廣元市利州區(qū)招聘事業(yè)單位工作人員50人歷年高頻重點(diǎn)提升(共500題)附帶答案詳解
- 2024年體育場(chǎng)館工程項(xiàng)目經(jīng)理勞動(dòng)合同2篇
- 云南財(cái)經(jīng)職業(yè)學(xué)院《禮儀文化》2023-2024學(xué)年第一學(xué)期期末試卷
- 2025年度股東借款及知識(shí)產(chǎn)權(quán)融資合同
- 第八版糖尿病
- 幼兒園后勤主任年終總結(jié)
- 機(jī)器人設(shè)備巡檢管理制度
- 帶式運(yùn)輸機(jī)傳動(dòng)裝置的設(shè)計(jì)
- DB50T 1689-2024 綠茶型老鷹茶加工技術(shù)規(guī)范
- 初級(jí)消防設(shè)施操作員實(shí)操題庫(kù) (一)
- 國(guó)家職業(yè)技術(shù)技能標(biāo)準(zhǔn) 4-02-01-01 軌道列車司機(jī)(動(dòng)車組司機(jī))人社廳發(fā)2019121號(hào)
- CURTIS1232-1234-1236-SE-SERIES交流控制器手冊(cè)
- 2024年國(guó)家開放大學(xué)(電大)-混凝土結(jié)構(gòu)設(shè)計(jì)(A)考試近5年真題集錦(頻考類試題)帶答案
- 2024年山東省臨沂蘭山法院招聘司法輔助人員56人歷年高頻500題難、易錯(cuò)點(diǎn)模擬試題附帶答案詳解
- 期末綜合素質(zhì)達(dá)標(biāo)(試題)-2024-2025學(xué)年人教精通版英語(yǔ)五年級(jí)上冊(cè)
評(píng)論
0/150
提交評(píng)論