Golang之sync.Pool對象池對象重用機制總結(jié)
sync.Pool作用
對象重用機制,為了減少GC,sync.Pool是可伸縮的,并發(fā)安全的
兩個結(jié)構(gòu)體
type Pool struct { local unsafe.Pointer // local fixed-size per-P pool, actual type is [P]poolLocal localSize uintptr // size of the local array // New optionally specifies a function to generate // a value when Get would otherwise return nil. // It may not be changed concurrently with calls to Get. New func() interface{} } // Local per-P Pool appendix. type poolLocal struct { private interface{} // Can be used only by the respective P. shared []interface{} // Can be used by any P. Mutex // Protects shared. pad [128]byte // Prevents false sharing. }
Pool是提供外部使用的對象,Pool有兩個重要的成員,local是一個poolLocal數(shù)組,localSize是工作線程的數(shù)量( runtime.GOMAXPROCS(0)),Pool為每個線程分配一個poolLocal對象
寫入和讀取
- Pool.Get 先獲取當(dāng)前線程私有值(poolLocal.private)獲取
否則則從共享列表(poolLocal.shared)獲取
否則則從其他線程的共享列表獲取
否則直接通過New()分配一個返回值 - Pool.Put 當(dāng)前線程私有制為空,賦值給私有值
否則追加到共享列表
sync.Pool注意點
臨時性,當(dāng)發(fā)生GC時,Pool的對象會被清除,并且不會有通知
無狀態(tài),當(dāng)前線程中的PoolLocal.shared的對象可能會被其他線程偷走
大規(guī)模Goroutine的瓶頸
會對垃圾回收(gc)造成負(fù)擔(dān),需要頻繁的釋放內(nèi)存
雖然goroutine只分配2KB,但是大量gorotine會消耗完內(nèi)存,并且gc也是goroutine調(diào)用的
原理和作用
原理類似是IO多路復(fù)用,就是盡可能復(fù)用,池化的核心優(yōu)勢就在于對goroutine的復(fù)用。此舉首先極大減輕了runtime調(diào)度goroutine的壓力,其次,便是降低了對內(nèi)存的消耗
到此這篇關(guān)于Golang之sync.Pool對象池對象重用機制總結(jié)的文章就介紹到這了,更多相關(guān)Golang sync.Pool對象重用機制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang實現(xiàn)Mongo數(shù)據(jù)庫增刪改查操作
本文主要介紹了Golang實現(xiàn)Mongo數(shù)據(jù)庫增刪改查操作,我們使用了 MongoDB的官方Go驅(qū)動程序,實現(xiàn)了插入、查詢、更新和刪除操作,感興趣的可以了解一下2024-01-01Golang IPv4 字符串與整數(shù)互轉(zhuǎn)方式
這篇文章主要介紹了Golang IPv4 字符串與整數(shù)互轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-11-11Go語言中切片(slice)和數(shù)組(array)的區(qū)別詳解
Go語言中切片(slice)和數(shù)組(array)是兩種不同的數(shù)據(jù)結(jié)構(gòu),它們在用法和行為上有一些重要區(qū)別,所以本文就通過一些代碼示例給大家詳細(xì)的介紹一下Go語言中切片(slice)和數(shù)組(array)的區(qū)別,需要的朋友可以參考下2023-09-09使用Go語言實現(xiàn)發(fā)送HTTP請求并給GET添加參數(shù)
在開發(fā)Web應(yīng)用程序時,我們經(jīng)常需要向服務(wù)器發(fā)送HTTP請求,本文將介紹一下使用Go語言發(fā)送HTTP請求,并給GET請求添加參數(shù)的方法,感興趣的小伙伴可以了解一下2023-07-07go使用consul實現(xiàn)服務(wù)發(fā)現(xiàn)及配置共享實現(xiàn)詳解
這篇文章主要為大家介紹了go使用consul實現(xiàn)服務(wù)發(fā)現(xiàn)及配置共享實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05通過函數(shù)如何將golang?float64?保留2位小數(shù)(方法匯總)
這篇文章主要介紹了通過函數(shù)將golang?float64保留2位小數(shù),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08