2014-09-09 8 views

risposta

8

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 
Problemi correlati