协程的一点认识

现在go语言的流行,越来越多的人开始关注协程。

协程大概是个用户空间的线程,由用户自己来进行调度。用这个大概可以少开点线程,一个线程多做点事情,调度更可控一些。

现在go,lua,python都有相关的支持吧。看网上有人也用boost asio的基础上写了一个,https://github.com/ioriiod0/orchid。
这个东西是怎么打造出来的呢?

主要用到asio里面的 ioservice,这个用来建立一个线程来运行其他线程post上来的函数操作,在windows上这个主要采用iocp来调用。
用户协程调度,主要用到,boost里面的一个新库boost::context,
http://www.boost.org/doc/libs/1_52_0/libs/context/doc/html/index.html,这个库主要用来保存函数运行到位置,以及相关函数堆栈信息。在orchid里面就表现为coroutine_basic.yield函数。在协程里面没什么事干都需要调用这个函数,sleep什么的也需要这个,不然就会堵塞在那,然后就开始运行下一个协程了。

反正这个就是一个线程里的协程,同一时间只是调用一个函数,这东西有点搅,反正要用起来,不是改一点点代码就可以了。

前天用了用python里面的gevent就发现个问题,导致阻塞。在使用gevent的同时直接试用raw_input,这个函数是得到输入
,没有输入就不返回,然后gevent就把他给协程了,这个函数里面没有触发他进行协程切换的操作,所以所有的协程都挂起了。

google了下,在gevent1.0里面已经解决了这个问题。

from gevent.fileobject import FileObject
sys.stdin =FileObject(sys.stdin)

这个相当于吧stdin给patch了,然后就正常了。

还是c++好啊,不需要协程的,再来一线程,一切均在控制。

你可能感兴趣的:(python,Go,asio,gevent,协程)