协程
Go 协程 在执行上来说是轻量级的线程。
package main
import "fmt"
func f(from string) {
for i := 0; i < 3; i++ {
fmt.Println(from, ":", i)
}
}
func main() {
// 假设我们有一个函数叫做 `f(s)`。我们使用一般的方式
// 调并同时运行。
f("direct")
// 使用 `go f(s)` 在一个 Go 协程中调用这个函数。
// 这个新的 Go 协程将会并行的执行这个函数调用。
go f("goroutine")
// 你也可以为匿名函数启动一个 Go 协程。
go func(msg string) {
fmt.Println(msg)
}("going")
// 现在这两个 Go 协程在独立的 Go 协程中异步的运行,所以
// 我们需要等它们执行结束。这里的 `Scanln` 代码需要我们
// 在程序退出前按下任意键结束。
var input string
fmt.Scanln(&input)
fmt.Println("done")
}
当我们运行这个程序时,将首先看到阻塞式调用的输出,然后是两个 Go 协程的交替输出。这种交替的情况表示 Go 运行时是以异步的方式运行协程的。
$ go run goroutines.go
direct : 0
direct : 1
direct : 2
goroutine : 0
going
goroutine : 1
goroutine : 2
<enter>
done
接下来我们将学习在并发的 Go 程序中的 Go 协程的辅助特性:通道。