协程诞生解决的是低速IO和高速的CPU的协调问题,解决这类问题主要有三个有效途径:
- 异步非阻塞网络编程(libevent、libev、redis、Nginx、memcached这类)
- 协程(golang、gevent)
- “轻量级线程”,至关因而在语言层面作抽象(Erlang)
对比之下协程的编程难度较低,不要求编程人员要有那么高的抽象思惟能力。再加上golang在这方面优秀的实践,协程目前的前途仍是一片光明的。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 来源:知乎 著做权归做者全部。商业转载请联系做者得到受权,非商业转载请注明出处。