多线程 – Golang阻塞和非阻塞
发布时间:2020-12-14 16:19:39 所属栏目:Java 来源:网络整理
导读:我对于如何处理非阻塞IO有点困惑. API主要看起来与我同步,在观看Go上的演示文稿时,听到诸如“和通话块”这样的意见并不罕见. 在从文件或网络读取文件时,Go会使用阻止IO吗? 或者在Go程序中使用时,是否有某种重现代码的魔法? 来自C#背景,这感觉非常不直观,在
我对于如何处理非阻塞IO有点困惑.
API主要看起来与我同步,在观看Go上的演示文稿时,听到诸如“和通话块”这样的意见并不罕见. 在从文件或网络读取文件时,Go会使用阻止IO吗? 来自C#背景,这感觉非常不直观,在C#中,在使用async API时,我们有一个等待关键字. 所以TLDR; 解决方法
Go有一个调度程序,可以让您编写同步代码,并自行进行上下文切换,并使用异步IO.所以,如果你运行几个goroutine,他们可能运行在一个单一的系统线程,当你的代码阻止从goroutine的视图,它不是真的阻止.这不是魔术,但是,它掩盖了你的所有这些东西.
调度程序将在需要时分配系统线程,并且在真正阻止的操作期间(我认为文件IO例如阻塞或调用C代码).但是,如果您正在做一些简单的http服务器,您可以使用几千个“真正的线程”来实现几千个goroutine. 您可以阅读更多关于Go的内部工作: https://morsmachine.dk/go-scheduler (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |