goroutine是由Go运行时环境管理的轻量级线程。
    在一个包中有一个函数
    goroutine 轻量级线程 - 图1

    goroutine使用 go say(“xxx”)来开启一个新的goroutine执行。
    运行下面的程序,观察运行结果。

    1. package main
    2. import (
    3. "time"
    4. "fmt"
    5. )
    6. func say(s string) {
    7. for i := 0; i < 5; i++{
    8. time.Sleep(100*time.Millisecond)
    9. fmt.Println(s)
    10. }
    11. }
    12. func main() {
    13. go say("Hello")
    14. say("world")
    15. }

    你会发现输出的Hello和world,没有固定的先后顺序。因为它们是两个goroutine在执行。

    如果系统运行的太快,可能你看不到所有的 go say(“Hello”)的运行结果。这时候,你可以修改time.Sleep(100time.Millisecond) 为 time.Sleep(500time.Millisecond)或更长的时间,就能够看到所有的运行结果了。


    goroutine 轻量级线程 - 图2