博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Go语言的并发和并行
阅读量:6417 次
发布时间:2019-06-23

本文共 1522 字,大约阅读时间需要 5 分钟。

  不知道你有没有注意到,这段代码如果我跑在两个goroutines里面的话:

  

package mainimport (    "fmt")func loop(done chan bool) {    for i := 0; i < 10; i++ {        fmt.Print(i)    }    done <- true}func main() {    done := make(chan bool)    go loop(done)    go loop(done)    <-done    <-done}

他的输出结果: 01234567890123456789

go不是会新起一个goroutine来运行loop函数吗。以前我们用线程去做类似任务的时候,系统的线程会抢占式地输出, 表现出来的是乱序地输出。而goroutine为什么是这样输出的呢?

 

关于并行和并发,下面这张图说明:

 

  • 两个队列,一个Coffee机器,那是并发
  • 两个队列,两个Coffee机器,那是并行

默认地, Go所有的goroutines只能在一个线程里跑 。

如果当前goroutine不发生阻塞,它是不会让出CPU给其他goroutine的, 所以上面的例子的输出会是一个一个goroutine进行的

 

真正的并行

为了达到真正的并行,runtime.GOMAXPROCS(2)试试看

package mainimport (    "fmt"    "runtime")func loop(done chan bool) {    for i := 0; i < 100; i++ {        fmt.Printf("%d ", i)    }    done <- true}func main() {    runtime.GOMAXPROCS(2)    done := make(chan bool)    go loop(done)    go loop(done)    <-done    <-done}

这下会看到两个goroutine会抢占式地输出数据了。我们还可以这样显式地让出CPU时间:

package mainimport (    "fmt"    "runtime")func loop(done chan bool) {    for i := 0; i < 100; i++ {        fmt.Printf("%d ", i)        runtime.Gosched()  //// 显式地让出CPU时间给其他goroutine    }    done <- true}func main() {    // runtime.GOMAXPROCS(2)    done := make(chan bool)    go loop(done)    go loop(done)    <-done    <-done}

总结

我们从例子中可以看到,默认的, 所有goroutine会在一个原生线程里跑

在同一个原生线程里,如果当前goroutine不发生阻塞,它是不会让出CPU时间给其他同线程的goroutines的,这是Go运行时对goroutine的调度,我们也可以使用runtime包来手工调度。

当一个goroutine发生阻塞,Go会自动地把与该goroutine处于同一系统线程的其他goroutines转移到另一个系统线程上去,以使这些goroutines不阻塞

 

转载于:https://www.cnblogs.com/hupengcool/p/3993823.html

你可能感兴趣的文章
Oracle API Availability – Profile
查看>>
Chromium Embedded Framework中文文档 (如何链接不同的运行时)
查看>>
【PAT】1029. Median (25)
查看>>
web项目的getContextPath()
查看>>
SpringMvc中两个Controller类之间传递参数的方法
查看>>
.NET Core微服务之路:基于Consul最少集群实现服务的注册与发现(二)
查看>>
【WP7】转:Windows Phone 7 开发 31 日谈 目录
查看>>
6. datasource - mysql【从零开始学Spring Boot】
查看>>
编写病毒程序取款700余万,华夏银行一技术处长被捕受审
查看>>
阿里成立达摩院做基础科研 这是一家被电商掩盖的科技公司
查看>>
iPhone X降价跌破天际,国内网友:不在乎!
查看>>
商贩被保安打死?警方:初步认定系其自身疾病所致
查看>>
澳洲网:中国留学生成“香饽饽” 受澳顶尖高校青睐
查看>>
鄱阳湖上的“高空杂技人”
查看>>
甘肃宕昌中药材“入方”饲料 “药香鸡”山外飘香助脱贫
查看>>
郑杨:上交所设立科创板工作正稳步推进 “沪伦通”年内启动
查看>>
苏索轰世界波 米兰2:0热那亚重返意甲前四
查看>>
中瑞创新产业中心在杭揭牌 千万补助推动科技创新交流
查看>>
辽宁经济走出最困难时期 GDP增速稳中有进
查看>>
程序员牛人专访0012期|陪伴是对开发最长情的信任
查看>>