第8章 Goroutines 和 Channels
Go语言中的并发程序可以用两种手段来实现:goroutine 和 channel,其支持顺序通信进程,或被简称为CSP,CSP是一种并发编程模型,在这种并发编程模型中,值会在不同运行实例中传递,第二个手段便是多线程共享内存
8.1 Goroutines
在Go语言中,每一个并发的执行单元叫作一个goroutine。当一个程序启动时,其主函数在一个单独的goroutine中运行,我们叫它main goroutine。新的goroutine会用go语句创建,即在函数或者方法前加上go,go语句会使其语句中的函数在一个新建的goroutine中运行,而go语句本身也会迅速完成
go f()
让我们写个函数看看
func main() {
go spinner(100 * time.Millisecond)
const n = 45
fibN := fib(n)
fmt.Printf("\rFibonacci(%d) = %d\n", n, fibN)
}
func spinner(delay time.Duration) {
for {
for _, r := range '-\|/' {
fmt.Printf("\r%c", r)
time.Sleep(delay)
}
}
}
func fib(x int) int {
if x < 2 {
return x
}
return fib(x-1) + fib(x-2)
}
函数运行会在几秒后出现结果
Fibonacci(45) = 1134903170
然后主函数返回,除了从主函数退出或者直接终止程序外,没有其它编程方法能够让一个goroutine打断另一个的执行,但是之后可以看到一种方式来实现这个目的,通过goroutine之间的通信来让一个goroutine请求其他的goroutine,并让被请求的goroutine自行结束执行
注意,fib函数和spinner函数是同时执行的