首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >厚土Go学习笔记 | 38. goroutine轻量级线程

厚土Go学习笔记 | 38. goroutine轻量级线程

作者头像
李海彬
发布2018-03-19 11:22:35
6110
发布2018-03-19 11:22:35
举报
文章被收录于专栏:Golang语言社区Golang语言社区

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(100*time.Millisecond)time.Sleep(500*time.Millisecond) 或者更长的时间,就能够看到所有的运行结果了。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-02-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Golang语言社区 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档