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还有很多其他的用法,之后可以挨个试试。

相关推荐
进击的圆儿23 分钟前
高并发内存池项目开发记录 - 02
开发语言·c++·实战·项目·内存池
xingxing_F28 分钟前
Swift Publisher for Mac 版面设计和编辑工具
开发语言·macos·swift
你才是向阳花30 分钟前
如何用python来做小游戏
开发语言·python·pygame
夜晚中的人海34 分钟前
【C++】使用双指针算法习题
开发语言·c++·算法
怀旧,36 分钟前
【Linux系统编程】3. Linux基本指令(下)
linux·开发语言·c++
艾莉丝努力练剑37 分钟前
【C++STL :stack && queue (三) 】优先级队列的使用以及底层实现
linux·开发语言·数据结构·c++·stl
web安全工具库2 小时前
Makefile 模式规则精讲:从 %.o: %.c 到静态模式规则的终极自动化
linux·运维·c语言·开发语言·数据库·自动化
從南走到北2 小时前
JAVA代泊车接机送机服务代客泊车系统源码支持小程序+APP+H5
java·开发语言·微信小程序·小程序
earthzhang20214 小时前
【1028】字符菱形
c语言·开发语言·数据结构·c++·算法·青少年编程
earthzhang20216 小时前
第3讲:Go垃圾回收机制与性能优化
开发语言·jvm·数据结构·后端·性能优化·golang