这篇文章将为大家详细讲解有关Golang与.NET中怎么实现协程,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
Golang goroutine
实现下面的代码可以显式指定编译器将goroutine调度到多个CPU上运行。
import "runtime"...runtime.GOMAXPROCS(4)
PS:runtime包中有几个处理goroutine的函数,
函数 | 说明 |
Goexit | 退出当前执行的goroutine,但是defer函数还会继续调用 |
Gosched | 让出当前goroutine的执行权限,调度器安排其他等待的任务运行,并在下次某个时候从该位置恢复执行 |
NumCPU | 返回 CPU 核数量 |
NumGoroutine | 返回正在执行和排队的任务总数 |
GOMAXPROCS | 用来设置可以并行计算的CPU核数的最大值,并返回之前的值 |
Go调度的几个概念:
M:内核线程;
G:go routine,并发的最小逻辑单元,由程序员创建;
P:处理器,执行G的上下文环境,每个P会维护一个本地的go routine队列;
除了每个P拥有一个本地的go routine队列外,还存在一个全局的go routine队列。
具体调度原理:
P的数量在初始化由GOMAXPROCS决定;
我们要做的就是添加G;
G的数量超出了M的处理能力,且还有空余P的话,runtime就会自动创建新的M;
M拿到P后才能干活,取G的顺序:本地队列>全局队列>其他P的队列,如果所有队列都没有可用的G,M会归还P并进入休眠;
说到.NET的Task模型与Golang的协程大同小异:
M = Thread
G = Task
P = Processor
关于Golang与.NET中怎么实现协程就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。