gobox中的shardmap

今天來說下gobox中的shardmap系忙。

golang中的map使用簡單惠豺,但并發(fā)寫入時银还,如果不加鎖,會導(dǎo)致panic蛹疯,所以性能很差。

shardmap就是為了解決這個問題热监,其核心思想就是通過創(chuàng)建多個map,把key做hash分配到這多個map上孝扛,從而減少鎖粒度以提高性能列吼。

用法示例

package main

import (
    "github.com/goinbox/shardmap"
    "github.com/goinbox/crypto"

    "fmt"
    "strconv"
)

func main() {
    shardMap := shardmap.New(32)

    hasError:=false
    for i := 0; i < 10000; i++ {
        key := crypto.Md5String([]byte(strconv.Itoa(i)))
        shardMap.Set(key, i)

        v, ok := shardMap.Get(key)
        if !ok || v != i {
            hasError = true
            fmt.Println(v, ok)
        }
    }

    if !hasError {
        fmt.Println("shardmap set get ok")
    }

    shardMap.Walk(func(k string, v interface{}) {
        shardMap.Del(k)

        _, ok := shardMap.Get(k)
        if ok {
            fmt.Println(v, ok)
        }
    })
}

輸出效果示例

shardmap set get ok

性能對比

我這里還做了和golang的原生map及sync包中提供的sync.Map的寫性能對比:

  • 原生map
BenchmarkSimpleMapWrite-4         300000          5935 ns/op
  • sync.Map
BenchmarkSyncMapWrite-4       200000          6831 ns/op
  • ShardMap
BenchmarkShardMapWrite-4      300000          3815 ns/op

歡迎大家使用苦始,使用中有遇到問題隨時反饋,我們會盡快響應(yīng)陌选,謝謝理郑!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咨油,一起剝皮案震驚了整個濱河市您炉,隨后出現(xiàn)的幾起案子役电,更是在濱河造成了極大的恐慌赚爵,老刑警劉巖法瑟,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件囱晴,死亡現(xiàn)場離奇詭異瓢谢,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)氓扛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人千所,你說我怎么就攤上這事∷饴瘢” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵整份,是天一觀的道長。 經(jīng)常有香客問我烈评,道長火俄,這世上最難降的妖魔是什么讲冠? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任瓜客,我火速辦了婚禮竿开,結(jié)果婚禮上谱仪,老公的妹妹穿的比我還像新娘否彩。我一直安慰自己疯攒,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布卸例。 她就那樣靜靜地躺著,像睡著了一般肌毅。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上悬而,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機(jī)與錄音笨奠,去河邊找鬼袭蝗。 笑死般婆,一個胖子當(dāng)著我的面吹牛到腥,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播乡范,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼配名,長吁一口氣:“原來是場噩夢啊……” “哼晋辆!你這毒婦竟也來了渠脉?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤芋膘,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后霸饲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡贴彼,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了器仗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片融涣。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡精钮,死狀恐怖威鹿,靈堂內(nèi)的尸體忽然破棺而出轨香,到底是詐尸還是另有隱情忽你,我是刑警寧澤臂容,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布科雳,位于F島的核電站脓杉,受9級特大地震影響糟秘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜尿赚,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蕉堰。 院中可真熱鬧莽龟,春花似錦矾缓、人聲如沸仲器。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至秒旋,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诀拭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工耕挨, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人筒占。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓贪庙,卻偏偏與公主長得像翰苫,于是被迫代替她去往敵國和親止邮。 傳聞我的和親對象是個殘疾皇子奏窑,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354

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

  • 在上篇中撩匕,我們已經(jīng)討論過如何去實現(xiàn)一個 Map 了,并且也討論了諸多優(yōu)化點墨叛。在下篇中,我們將繼續(xù)討論如何實現(xiàn)一個線...
    一縷殤流化隱半邊冰霜閱讀 7,624評論 5 41
  • 1.ios高性能編程 (1).內(nèi)層 最小的內(nèi)層平均值和峰值(2).耗電量 高效的算法和數(shù)據(jù)結(jié)構(gòu)(3).初始化時...
    歐辰_OSR閱讀 29,383評論 8 265
  • 生活里總有些莫名的情緒讓人觸不及防扁凛,跟往常一樣聽了幾百遍的《梵高先生》照例在深夜歌單隨機(jī),今晚不知怎的這個生來就是...
    梵高先生在鼓樓閱讀 371評論 0 0
  • 樹立目標(biāo)棚潦,為實現(xiàn)目標(biāo)而制定計劃是“預(yù)測未來,活在未來”的一種體現(xiàn)丸边。任何事情都可以制定計劃叠必,分解開來按步驟去做,包括...
    xll2068閱讀 1,108評論 8 3
  • 從上篇文章風(fēng)險管理相關(guān)國際標(biāo)準(zhǔn)和國際組織纬朝,我們從標(biāo)準(zhǔn)類別上將風(fēng)險管理的國際標(biāo)準(zhǔn)分為通用性標(biāo)準(zhǔn)及各行業(yè)特殊應(yīng)用型標(biāo)準(zhǔn)...
    威威專欄閱讀 1,322評論 0 1