在函数里开一个 goroutine 并不会因为函数的结束而退出,所以以下有一段代码是我在网站上找到的,我略作修改,以证明这种办法无法让goroutine退出,在函数终结退出后,依然有routine在奔跑,
请教大家如何杀死goroutine?不甚感激::::
for {
go 拜谢()
}
http://bbs.mygolang.com/thread-18-1-1.html
package main
import (
"fmt"
"runtime"
"time"
)
func job(ch int, timeout time.Duration) {
t := time.NewTimer(timeout)
defer t.Stop()
flg := make(chan bool, 1)
//执行真正的处理,这里用sleep模拟
go func(tm int) {
i := 0
for i < tm {
fmt.Println(ch, "is running...")
i++
time.Sleep(1 * time.Second)
}
flg <- true
}(ch)
//监听通道,由于设有超时,不可能泄露
select {
case <-t.C:
fmt.Println(ch, "time out")
case <-flg:
//正常退出
fmt.Println("job", ch, "end")
return
}
}
func main() {
runtime.GOMAXPROCS(4)
timeout := 10 * time.Second
//启动3个goroutine,若超时的话会自动退出
go job(1, timeout)
go job(200, timeout)
go job(5, timeout)
time.Sleep(60 * time.Second)
}
唉,你就不能仔细看看楼主大意思么?
//执行真正的处理,这里 http.Get()
go func(tm int) {
i := 0
for i < tm {
b := false
select {
case <-quit:
b = true
default:
fmt.Println(ch, "is running...")
i++
// time.Sleep(1 * time.Second)
http.Get("wtf_url")
}
if b {
break
}
}
flg <- true
}(ch)
本来想 10s 后结束那个 goroutime, 但 tmd http.Get 就跑了一分钟.
你觉得你这是办法么?
#11
更多评论
可以让一个 goroutine 监听一个 channel,另外一个 goroutine 给这个channel发送一个退出信号,收到这个信号的goroutine退出。
#1
> 在函数里开一个 goroutine 并不会因为函数的结束而退出
这个是肯定的啦。
硬要 timeout, 你要么放弃那个函数的结果,要么让它自生自灭.
<a href="/user/polaris" title="@polaris">@polaris</a> 楼主是想停掉 **一个** 正在工作的 goroutime, 怎么能又让它工作又让它监听 channel ?
#2