Go语言自学系列 | golang并发编程之runtime包

Posted COCOgsta

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Go语言自学系列 | golang并发编程之runtime包相关的知识,希望对你有一定的参考价值。

视频来源:B站《golang入门到项目实战 [2021最新Go语言教程,没有废话,纯干货!持续更新中...]》

一边学习一边整理老师的课程内容及试验笔记,并与大家分享,请移步至知乎网站,谢谢支持!

附上汇总贴:Go语言自学系列 | 汇总 - 知乎 (zhihu.com)https://zhuanlan.zhihu.com/p/484035621


runtime包里面定义了一些协程管理相关的api

runtime.Gosched()

让出CPU时间片,重新等待安排任务

package main 
 
import ( 
    "fmt" 
    "runtime" 
) 
 
func show(s string)  
    for i := 0; i < 2; i++  
        fmt.Println(s) 
     
 
 
func main()  
    go show("java") 
    // 主协程 
    for i := 0; i < 2; i++  
        // 切一下,再次分配任务 
        runtime.Gosched() // 注释掉查看结果 
        fmt.Println("golang") 
     
 
 

运行结果

[Running] go run "d:\\SynologyDrive\\软件开发\\go\\golang入门到项目实战\\goproject\\360duote.com\\pro01\\test.go" 
java 
java 
golang 
golang 
 

runtime.Goexit()

退出当前协程

package main 
 
import ( 
    "fmt" 
    "runtime" 
    "time" 
) 
 
func show(s string)  
    for i := 0; i < 10; i++  
        if i >= 5  
            runtime.Goexit() 
         
        fmt.Printf("i: %v\\n", i) 
     
 
 
func main()  
    go show("java") 
    time.Sleep(time.Second) 
 
 

运行结果

[Running] go run "d:\\SynologyDrive\\软件开发\\go\\golang入门到项目实战\\goproject\\360duote.com\\pro01\\test.go" 
i: 0 
i: 1 
i: 2 
i: 3 
i: 4 
 

runtime.GOMAXPROCS

package main 
 
import ( 
    "fmt" 
    "runtime" 
    "time" 
) 
 
func a()  
    for i := 0; i < 10; i++  
        fmt.Println("A:", i) 
        time.Sleep(time.Millisecond * 100) 
     
 
 
func b()  
    for i := 0; i < 10; i++  
        fmt.Println("B:", i) 
     
 
 
func main()  
    fmt.Printf("runtime.NumCPU(): %v\\n", runtime.NumCPU()) 
    runtime.GOMAXPROCS(2) // 修改为1查看效果 
    go a() 
    go b() 
    time.Sleep(time.Second) 
 
 

运行结果

[Running] go run "d:\\SynologyDrive\\软件开发\\go\\golang入门到项目实战\\goproject\\360duote.com\\pro01\\test.go" 
runtime.NumCPU(): 8 
B: 0 
B: 1 
B: 2 
A: 0 
B: 3 
B: 4 
B: 5 
B: 6 
B: 7 
B: 8 
B: 9 
A: 1 
A: 2 
A: 3 
A: 4 
A: 5 
A: 6 
A: 7 
A: 8 
A: 9 
 

如果修改最大核心数为1,运行结果如下,不会出现交替执行现象

[Running] go run "d:\\SynologyDrive\\软件开发\\go\\golang入门到项目实战\\goproject\\360duote.com\\pro01\\test.go" 
runtime.NumCPU(): 8 
B: 0 
B: 1 
B: 2 
B: 3 
B: 4 
B: 5 
B: 6 
B: 7 
B: 8 
B: 9 
A: 0 
A: 1 
A: 2 
A: 3 
A: 4 
A: 5 
A: 6 
A: 7 
A: 8 
A: 9 
 

以上是关于Go语言自学系列 | golang并发编程之runtime包的主要内容,如果未能解决你的问题,请参考以下文章

Go语言自学系列 | golang并发编程之runtime包

Go语言自学系列 | golang并发编程之原子操作详解

Go语言自学系列 | golang并发编程之WaitGroup实现同步

Go语言自学系列 | golang并发编程之原子变量的引入

Go语言自学系列 | golang并发编程之channel的遍历

Go语言自学系列 | golang并发编程之select switch