Quelli non sono fili, sono goroutines, e il numero può variare in base implementazione corrente (cioè in go1.2 verrebbe stampato 2).
Al momento, sembra che tu abbia 1 per main
e 3 per runtime/gc.
import "fmt"
func main() {
fmt.Println(func() string { panic(nil); return "" }())
}
Questo dimostra
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
se si rimuove fmt, e utilizzare la funzione di avvio automatico print
si ottiene solo 2 goroutines.
import "runtime"
func main() {
print(runtime.NumGoroutine(), "\n")
}
// prints 2
Se mai voglia di sapere esattamente che cosa goroutines sono in esecuzione, stampare una traccia dello stack, chiamare il panico, o uccidere il processo con SIGQUIT (che stampa una traccia dello stack ed esce). Se si esegue il programma minimo assoluto è possibile ottenere una traccia dello stack da voi possono vedere le 2 goroutines:
package main
func main() {
panic(nil)
}
Goroutines sono molto economici, e molte cose inizierà e terminerà più goroutines, quindi cercando di rintracciare la loro il limite inferiore non è molto utile. Nota come ci siano solo 2 goroutine, (main/runtime.panic e runtime.MHeap_Scavenger), il conteggio è già fino a 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