这个对协程的分析不错

协程诞生解决的是低速IO和高速的CPU的协调问题,解决这类问题主要有三个有效途径:
  1. 异步非阻塞网络编程(libevent、libev、redis、Nginx、memcached这类)
  2. 协程(golang、gevent)
  3. “轻量级线程”,相当于是在语言层面做抽象(Erlang)

对比之下协程的编程难度较低,不要求编程人员要有那么高的抽象思维能力。再加上golang在这方面优秀的实践,协程目前的前途还是一片光明的。

当然还有一点,我们要承认无论你状态机、callback设计得多么精妙,现实中阻塞事很难以避免的。
  • 避免了Network IO Blocking,还有
  • Disk IO Blocking,还有
  • 数据库Blocking,还有
  • 日志Blocking,还有
  • 第三方库blocking,还有
  • 愚蠢的人类blocking……
协程是应对这些的不错的解决方案,当然协程的接口还是太过晦涩。
So,Life is Short,Use Golang。
线程还是更适合作为多核计算的不二法门存在的。


作者:auxten
链接:https://www.zhihu.com/question/32218874/answer/67525705
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
posted @   blcblc  阅读(300)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示