登录
首页 >  Golang >  Go问答

epoll集成的优点

来源:stackoverflow

时间:2024-04-09 13:15:33 200浏览 收藏

有志者,事竟成!如果你在学习Golang,那么本文《epoll集成的优点》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

在一次工作面试中,我必须回答这个问题 - 由于在 Go 中使用 epoll 集成/实现,您有哪些优势。

我只知道 epoll 可以做什么,并且任何描述符计数的复杂性都是 O(1),但不知道为什么 Go 比其他语言更好。

我发现这个分支 https://news.ycombinator.com/item?id=15624586 ,有人说这个原因也许是 Go 不使用堆栈切换。对我来说很难理解。程序的哪一部分不使用堆栈切换?每个 goroutine 都有自己的堆栈。


解决方案


这并不是让 Go 在其领域变得强大的 netpoller 集成本身,而是集成的实现方式:在 Go 中,netpoller 不是作为一个库固定下来的,而是紧密集成到运行时和调度程序(决定运行哪个 goroutine 以及何时运行)。

超轻量级执行线程(goroutine)与 netpoller 的耦合允许无回调编程。也就是说,一旦您的服务连接到另一个客户端,您只需将此连接交给一个 goroutine,该 goroutine 仅从中读取数据(并将其响应流写入其中)。一旦 goroutine 想要读取数据时没有可用数据,调度程序就会挂起 goroutine,并在 netpoller 报告有可用数据后解除阻塞;当 goroutine 想要写入数据但发送缓冲区已满时,也会发生同样的情况。

回顾一下,Go 中的 netpoller 与 goroutine 调度程序交织在一起,它允许 goroutine 透明地等待数据可用性,而不需要程序员显式编码事件循环和回调或处理纯粹是回调的“futures”和“promises”包裹在漂亮的物体中。

我邀请您阅读 this classic essay,它用更漂亮的文字解释了这些内容。

本篇关于《epoll集成的优点》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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