btcd-go 中l(wèi)og部分代碼解讀

btcd-go 中l(wèi)og部分代碼

整體設(shè)計(jì)

interface : Logger 
struct: slog 
struct: Backend 
Backend
type Backend struct {
   w io.Writer
   mu sync.Mutex // ensures atomic writes
   flag uint32
}

主要實(shí)現(xiàn)了線程安全的print, printf功能何吝,即格式化要打印日志灼擂。 w 這個(gè)writer做為初始參數(shù)走贪,可以從外面?zhèn)鬏斍蚯校鈽?gòu)writer勾徽,方便自己配置writer,比如std.Out/std.Err 等實(shí)現(xiàn)了Writer接口的struct即可谓谦。

Backend還實(shí)現(xiàn)了一個(gè)創(chuàng)建實(shí)例的工廠函數(shù):

func (b* Backend) Logger(subsystemTag string) Logger {
    return &slog{LevelInfo, subsystemTag, b}
}
slog
type slog struct {
    lvl Level
    tag string
    b *Backend
}

這個(gè)類實(shí)現(xiàn)了interface: Logger所有接口贫橙。 而內(nèi)部實(shí)現(xiàn)事業(yè) Backend. 通過(guò)Level來(lái)控制日志顯示級(jí)別。 tag來(lái)標(biāo)識(shí)日志來(lái)自某個(gè)子系統(tǒng) subsystem.

以字符形式反粥,按固定長(zhǎng)度輸出數(shù)字卢肃,長(zhǎng)度不夠,前面用0補(bǔ)齊才顿。

但是這個(gè)算法莫湘,只要i大于0才能正常工作,所以娜膘,把i類型改成uint更合適

// From stdlib log package.
// Cheap integer to fixed-width decimal ASCII.  Give a negative width to avoid
// zero-padding.
func itoa(buf *[]byte, i int, wid int) {
    // Assemble decimal in reverse order.
    var b [20]byte
    bp := len(b) - 1
    for i >= 10 || wid > 1 {
        wid--
        q := i / 10
        b[bp] = byte('0' + i - q*10)
        bp--
        i = q
    }
    // i < 10
    b[bp] = byte('0' + i)
    *buf = append(*buf, b[bp:]...)
}

給slice賦值為0的用法

// recycleBuffer puts the provided byte slice, which should have been obtain via
// the buffer function, back on the free list.
func recycleBuffer(b *[]byte) {
   *b = (*b)[:0]
   bufferPool.Put(b)
}

其中的 *b = (*b)[:0] 就是把b 這個(gè)byte slice賦值為0

多go routine下逊脯,使用pool來(lái)

var bufferPool = sync.Pool{
   New: func() interface{} {
      b := make([]byte, 0, 120)
      return &b
   },
}

如果有多個(gè)go routine 輸出日志,可使用pool來(lái)避免竣贪,競(jìng)爭(zhēng)同一個(gè)緩存军洼,如使用同一個(gè)緩存巩螃,會(huì)導(dǎo)致其他go routine掛起,而只在writer寫數(shù)據(jù)時(shí)匕争,才使用Mutex來(lái)同步避乏,這樣效率更高,用空間換時(shí)間甘桑。

參考

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拍皮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子跑杭,更是在濱河造成了極大的恐慌铆帽,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件德谅,死亡現(xiàn)場(chǎng)離奇詭異爹橱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)窄做,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門愧驱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人椭盏,你說(shuō)我怎么就攤上這事组砚。” “怎么了掏颊?”我有些...
    開(kāi)封第一講書人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵糟红,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我蚯舱,道長(zhǎng)改化,這世上最難降的妖魔是什么掩蛤? 我笑而不...
    開(kāi)封第一講書人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任枉昏,我火速辦了婚禮,結(jié)果婚禮上揍鸟,老公的妹妹穿的比我還像新娘兄裂。我一直安慰自己,他們只是感情好阳藻,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布晰奖。 她就那樣靜靜地躺著,像睡著了一般腥泥。 火紅的嫁衣襯著肌膚如雪匾南。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,292評(píng)論 1 301
  • 那天蛔外,我揣著相機(jī)與錄音蛆楞,去河邊找鬼溯乒。 笑死,一個(gè)胖子當(dāng)著我的面吹牛豹爹,可吹牛的內(nèi)容都是我干的裆悄。 我是一名探鬼主播,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼臂聋,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼光稼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起孩等,我...
    開(kāi)封第一講書人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤艾君,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后肄方,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體腻贰,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年扒秸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了播演。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伴奥,死狀恐怖写烤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拾徙,我是刑警寧澤洲炊,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站尼啡,受9級(jí)特大地震影響暂衡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜崖瞭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一狂巢、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧书聚,春花似錦唧领、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至驯杜,卻和暖如春受啥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工滚局, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留叁温,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓核畴,卻偏偏與公主長(zhǎng)得像膝但,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子谤草,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

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

  • 將兩個(gè)(或更多)語(yǔ)句放在一行書寫跟束,它們 必須用分號(hào) (’;’) 分隔。一般情況下丑孩,你不需要分號(hào)冀宴。 init函數(shù)和m...
    涵仔睡覺(jué)閱讀 3,789評(píng)論 0 8
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)温学,斷路器略贮,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139
  • 不知不覺(jué)春天已經(jīng)來(lái)了,它來(lái)的無(wú)聲無(wú)息卻又熱鬧非凡仗岖,冬天的時(shí)候逃延,大部分樹為了安度冬季都把葉子脫落,自己留下光禿禿的枝...
    說(shuō)書客閱讀 151評(píng)論 0 0
  • 1.OS_OBJECT_USE_OBJC ios6.0之后OS_OBJECT_USE_OBJC是1 只是配置項(xiàng)里可...
    人仙兒a閱讀 1,106評(píng)論 0 1
  • 1 解決辦法重啟:File -> Invalidate Caches / Restart… -> Invalida...
    凱玲之戀閱讀 197評(píng)論 0 0