go语言并发编程2-runtime

runtime.Gosched()

作用是让出CPU时间片,重新等待安排任务。执行runtime.Gosched()后,其他协程优先执行,当前所在协程最后执行。

golang 复制代码
package main

import (
	"fmt"
	"runtime"
)

func main() {
	go func(s string) {
		for i := 0; i < 10; i++ {
			fmt.Println(s)
		}
	}("world")
	// 主协程
	for i := 0; i < 2; i++ {
		// 切一下,再次分配任务
		runtime.Gosched()
		fmt.Println("hello")
	}
}

runtime.Goexit()

终止协程,不再调用,注意不能在main方法中终止,会触发panic.

go 复制代码
package main

import (
	"fmt"
	"runtime"
	"time"
)

func printHello() {
	defer fmt.Println("end func printHello")
	for i := 1; i < 10; i++ {
		fmt.Println("start print")
		if i%4 == 0 {
			runtime.Goexit()
		}
		fmt.Printf("start print:%d\n", i)
	}
}

func main() {
	go printHello()
	time.Sleep(6 * time.Second)
}

由以上代码可以看出,实际上触发runtime.Goexit()后,协程立即停止运行了。

runtime.GOMAXPROCS

设置最大运行核心数,Go运行时的调度器使用GOMAXPROCS参数来确定需要使用多少个OS线程来同时执行Go代码

其他

runtime包实际上有非常多方法,例如加上panic的trace信息:

golang 复制代码
package main

import (
	"fmt"
	"runtime"
	"time"
)

func a() {
	err := runtime.StartTrace()
	if err != nil {
		return
	}
	fmt.Println("start trace__")
	defer fmt.Printf("done")
	for i := 1; i < 10; i++ {
		if i%4 == 0 {
			panic("err non")
		}
	}
	runtime.StopTrace()
}

func main() {
	go a()
	time.Sleep(time.Second)
}

runtime还有很多其他的用法,之后可以挨个试试。

相关推荐
古城小栈4 分钟前
Java 响应式编程:Spring WebFlux+Reactor 实战
java·开发语言·spring
攻心的子乐6 分钟前
sentinel使用指南 限流/熔断 微服务 ruoyi-cloud使用了
java·开发语言
点云SLAM8 分钟前
C++ 偏特化详解
开发语言·c++·c++模板·c++17·c++高级应用·c++偏特化·大型项目
wregjru8 分钟前
【C++】2.3 二叉搜索树的实现(附代码)
开发语言·前端·javascript
柒.梧.14 分钟前
Java核心面试题终极总结:从基础到进阶,覆盖高频考
java·开发语言·面试
黎雁·泠崖16 分钟前
C 语言字符串入门:字符函数 + strlen 精讲(从使用到模拟实现)
c语言·开发语言
星环处相逢16 分钟前
Docker资源限制全解析:CPU、内存、磁盘IO管控与实操指南
java·开发语言
white-persist17 分钟前
【攻防世界】reverse | tt3441810 详细题解 WP
java·c语言·开发语言·数据结构·c++·算法·安全
四维碎片17 分钟前
【Qt】为什么QList是数组
开发语言·qt
古城小栈18 分钟前
Go + 区块链:模块化链节点开发实践
开发语言·golang·区块链