Go似乎总是在任何给定时间至少运行4个goroutines。还有哪三个不是主要的goroutine?
http://play.golang.org/p/MQBiLmHXBK
package main
import (
"fmt"
"runtime"
)
func main() {
fmt.Println(runtime.NumGoroutine()) //4
}
答案 0 :(得分:8)
那些不是线程,它们是goroutines,并且数量可能会根据当前的实现而有所不同(例如,在它将打印2的go1.2中)。
现在看来,main
有1个,运行时/ gc有3个。
import "fmt"
func main() {
fmt.Println(func() string { panic(nil); return "" }())
}
显示
goroutine 16 [running]:
runtime.panic(0x0, 0x0)
/usr/local/go/src/pkg/runtime/panic.c:279 +0xf5
main.func·001(0x3ea4f, 0xdc4b0)
/test/threads.go:6 +0x28
main.main()
/test/threads.go:6 +0x1e
goroutine 17 [runnable]:
runtime.MHeap_Scavenger()
/usr/local/go/src/pkg/runtime/mheap.c:507
runtime.goexit()
/usr/local/go/src/pkg/runtime/proc.c:1445
goroutine 18 [runnable]:
bgsweep()
/usr/local/go/src/pkg/runtime/mgc0.c:1976
runtime.goexit()
/usr/local/go/src/pkg/runtime/proc.c:1445
goroutine 19 [runnable]:
runfinq()
/usr/local/go/src/pkg/runtime/mgc0.c:2606
runtime.goexit()
/usr/local/go/src/pkg/runtime/proc.c:1445
如果删除fmt,并使用bootstrapping print
函数,则只能获得2个goroutines。
import "runtime"
func main() {
print(runtime.NumGoroutine(), "\n")
}
// prints 2
如果您想确切知道正在运行的goroutine,请打印堆栈跟踪,调用panic或使用SIGQUIT(打印堆栈跟踪并退出)终止进程。如果您运行绝对最小程序,您可以从中获得堆栈跟踪,可以看到2个goroutines:
package main
func main() {
panic(nil)
}
Goroutines非常便宜,很多的东西会启动和停止更多的goroutines,所以试图追踪它们的下限并不是非常有用。请注意,即使只有2个goroutine(main / runtime.panic和runtime.MHeap_Scavenger),计数已经达到17个。
panic: nil
goroutine 16 [running]:
runtime.panic(0x0, 0x0)
/usr/local/go/src/pkg/runtime/panic.c:279 +0xf5
main.main()
/test/threads.go:4 +0x28
goroutine 17 [runnable]:
runtime.MHeap_Scavenger()
/usr/local/go/src/pkg/runtime/mheap.c:507
runtime.goexit()
/usr/local/go/src/pkg/runtime/proc.c:1445
exit status 2