Golang timer可能造成的內(nèi)存泄漏問題分析
Golang timer可能造成的內(nèi)存泄漏
背景
前兩天,跟一位學長交流Golang;然后,他突然問我:你知道timer可能造成內(nèi)存泄漏嘛?
當時,甚是一臉懵逼,畢竟之前寫的Agent測了好久,都沒發(fā)現(xiàn)這個問題啊。
今天,就索性了解了下。
這里先說下結論:
- timer的誤用可能造成某些等待timer的Goroutine無法正常退出,導致資源無法釋放;
- (ps. 雖然的確算是內(nèi)存泄漏,但是對于我這種寫C出身的人來說,感覺還是怪怪的)
接下來進入正題
讓我們先看一段代碼;
這段代碼的意圖是,協(xié)程在timer.Stop()調(diào)用后能夠繼續(xù)執(zhí)行從而退出;
但是,實際的效果呢? 我們沒有看到任何輸出提示;
那是為什么呢?
這當中核心的原因就是,timer.Stop() 這個接口從設計的時候就設計成了并不去關閉Channel;
既然不關閉Chan,那么本例中的協(xié)程也就無法繼續(xù)執(zhí)行,從而退出了;
package main import ( "time" "fmt" ) func main() { timer := time.NewTimer(3 * time.Second) go func() { <-timer.C fmt.Println("Timer has expired.") }() timer.Stop() time.Sleep(60 * time.Second) }
作為一種修復手段:
package main import ( "time" "fmt" ) func main() { timer := time.NewTimer(3 * time.Second) go func() { <-timer.C fmt.Println("Timer has expired.") }() //timer.Stop() timer.Reset(0 * time.Second) time.Sleep(60 * time.Second) }
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Golang 模塊引入及表格讀寫業(yè)務快速實現(xiàn)示例
這篇文章主要為大家介紹了Golang模塊引入及表格讀寫業(yè)務的快速實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07CMD下執(zhí)行Go出現(xiàn)中文亂碼的解決方法
需要在Go寫的服務里面調(diào)用命令行或者批處理,并根據(jù)返回的結果做處理。但是windows下面用cmd返回中文會出現(xiàn)亂碼,本文就詳細的介紹一下解決方法,感興趣的可以了解一下2021-12-12