Goroutines

Goroutines->协程 #

// _协程(goroutine)_ 是轻量级的执行线程。

package main

import (
	"fmt"
	"time"
)

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 f("goroutine")

	// 你也可以为匿名函数启动一个协程。
	go func(msg string) {
		fmt.Println(msg)
	}("going")

	// 现在两个协程在独立的协程中 `异步地` 运行,
	// 然后等待两个协程完成(更好的方法是使用 [WaitGroup](waitgroups))。
	time.Sleep(time.Second)
	fmt.Println("done")
}
# 当我们运行这个程序时,首先会看到阻塞式调用的输出,然后是两个协程的交替输出。
# 这种交替的情况表示 Go runtime 是以并发的方式运行协程的。
$ go run goroutines.go
direct : 0
direct : 1
direct : 2
goroutine : 0
going
goroutine : 1
goroutine : 2
done

# 接下来我们将学习协程的辅助特性:通道(channels)。