38. goroutine轻量级线程

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

say(s string)

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

package main

import (
    "time"
    "fmt"
)

func say(s string)  {
    for i := 0; i < 5; i++{
        time.Sleep(100*time.Millisecond)
        fmt.Println(s)
    }
}
func main() {
    go say("Hello")
    say("world")
}

你会发现输出的 Hello 和 world ,没有固定的先后顺序。因为它们是两个 goroutine 在执行。
如果系统运行的太快,可能你看不到所有的 go say("Hello") 的运行结果。这时候,你可以修改 time.Sleep(100time.Millisecond) 为 time.Sleep(500time.Millisecond) 或者更长的时间,就能够看到所有的运行结果了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容