登录
首页 >  Golang >  Go问答

当IO操作阻塞goroutine时,它们会发生什么?

来源:stackoverflow

时间:2024-02-21 09:18:24 149浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《当IO操作阻塞goroutine时,它们会发生什么?》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

假设一个 goroutine 正在从网络读取数据。每次 goroutine 必须等待(被阻塞等待网络响应)时,会发生什么?运行 goroutine 的操作系统线程是否被阻塞?还是像C#中的异步操作一样工作(线程返回线程池,直到操作系统的IO线程通知程序有新数据需要处理,然后线程池中的另一个线程继续处理数据)从网络收到)?

我主要担心的是,如果每次 goroutine 被阻塞时 Go 都会保留一个阻塞线程,如果我在服务器中有很多 goroutine 处理来自非常慢的网络的传入连接,我最终可能会耗尽 RAM,因为每个 goroutine 都会被阻塞这些被阻塞的线程消耗了大约 2MB 的 RAM。或者如果Go创建的用于运行goroutines的线程池有限制,我可能最终会失去活力。

那么 goroutine 在 IO 绑定操作中如何表现?


解决方案


如果它是一个异步系统调用,它会阻塞 goroutine 并释放线程以运行另一个 goroutine,就像 goroutine 阻塞一样。读取频道。

如果它是一个阻塞系统调用,Go 对此无能为力 - 系统调用将阻塞线程,期间。 Go 可能会启动另一个线程来处理由调度程序确定的可运行的 goroutine。

终于介绍完啦!小伙伴们,这篇关于《当IO操作阻塞goroutine时,它们会发生什么?》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>