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

