gorotine调度yield机制笔记

goroutine是Go语言的轻量级协程,当执行完毕或遇到阻塞会主动放弃CPU资源,这种行为称为yield。yield是协作式调度,可由程序员通过调用runtime.Gosched()实现。它帮助避免长时间占用CPU和过度竞争,提升并发性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        goroutine是Go语言中轻量级协程。当一个goroutine执行完毕或者遇到阻塞时,就会主动放弃CPU资源,让其他等待执行的goroutine有机会执行。这个主动放弃CPU资源的行为就是yield。

        goroutine中,yield是一种协作式的调度方式,和pre-emption(强制抢占)一起配合。pre-emption是runtime强制使得该协程放弃执行权,而yield是可以由程序员主动控制并放弃资源。

        yield通过在代码中主动调用runtime.Gosched()函数来放弃当前执行权

        评价方面:yield机制通过主动放弃CPU资源,避免了长时间占用CPU资源和过度竞争的问题,提高了程序的并发性能

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值