登录
首页 >  Golang >  Go问答

将产生 goroutines 的 golang 方法

来源:Golang技术栈

时间:2023-03-21 20:58:23 109浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《将产生 goroutines 的 golang 方法》,聊聊golang,我们一起来看看吧!

问题内容

据我了解,如果 goroutines 太忙,它们会阻止其他 goroutines 运行。对我来说,这意味着我的应用程序的性能和响应能力可能取决于我是否知道哪些库方法将控制其他 goroutine(例如通常是 Read() 和 Write())

有什么方法可以让我确切地知道不同的库方法将如何控制其他 goroutine,即实际上不会阻塞?

有什么方法可以实现调用第三方代码的新方法(包括异步 Win32 API,例如依赖于 waitforsingleobject 或 waitformultipleobjects 的 findnextchangenotification )并在 Go 调度程序中表现得“不错”?在这个特定的例子中,系统调用一旦完成就会发出信号,我需要等到它完成而不用尽所有其他 goroutine。

对于如何处理 Go 中的第三方阻塞操作,是否还有另一种“最佳实践”,以免它们耗尽其他 goroutine?

我假设 Go 运行时可能在后台线程上内部运行某种 IO 循环,以便“暂停”阻塞 goroutine 操作,直到它们完成 IO。如果确实如此,那么我想能够在此基础上构建新的阻塞操作可能会很有用。

正确答案

Go 的调度程序将暂停等待系统调用的 goroutine,并在系统调用完成时唤醒它们,为您提供一个同步 API 来处理异步调用。

阅读有关调度程序如何工作的更多信息。

然而,没有确切的方法来确定哪个 goroutine 将被一个接一个地唤醒或将控制权从一个 goroutine 直接交给另一个 goroutine ——这是调度程序的工作。

您所关心的问题是 Go 中已解决的问题,您不必担心 - 编码!

编辑:

进一步澄清;您不应该编写代码以符合(或更好地利用)Go 调度程序的语义——而是相反。可能有一些代码技巧可以让你今天稍微提高性能,但调度程序可以并且将会在任何未来的 Go 版本中发生变化——使你的代码优化无用甚至对你不利。

终于介绍完啦!小伙伴们,这篇关于《将产生 goroutines 的 golang 方法》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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