Python中Tornado协程的使用详解(附实例)


当前第2页 返回上一页

【启动IOLoop】》【调用被lambda封装的协程函数】》【停止IOLoop】

实例:在IOLoop启动时,通过spawn_callback()函数调用

代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

#用协程技术开发网页访问功能

from tornado import  gen #引入协程库gen

from tornado.httpclient import AsyncHTTPClient

from tornado.ioloop import IOLoop  #引入IOLoop对象

 

#使用gen.coroutine修饰器

@gen.coroutine

def coroutine_visit():

    http_client=AsyncHTTPClient()

    response=yield http_client.fetch("http://www.baidu.com")

    print(response.body)

 

def func_normal():

    print("start call coroutine_visit")

    IOLoop.current().spawn_callback(coroutine_visit)

    print("end call coroutine_visit")

spawn_callback()函数将不会等待被调用协程执行完成,所有上下两条打印语句将马上完成,而coroutine__visit本身将会由IOLoop在合适的时机进行调用。

注意:IOLoop的spawn_callback()函数没有为开发者提供获取协程函数调用返回值的方法,所以只能用span_callback()调用没有返回值的协程函数。

3、在协程中调用阻塞函数

在协程中直接调用阻塞函数会影响协程本身的性能,所以Tornado提供了在协程中利用线程池调度阻塞函数,从而不影响协程本身继续执行的方法。

代码实例:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

from concurrent.futures import ThreadPoolExecutor

from tornado import gen

 

#定义线程池

thread_pool=ThreadPoolExecutor(2)

 

def mySleep(count):

    import time

    for x in range(count):

        time.sleep(1)

 

@gen.coroutine

def call_blocking():

    print("start")

    yield thread_pool.submit(mySleep,10)

    print("end")

代码中首先引用了concurrent.futures种的ThreadPoolExecutor类,实例化了一个由两个线程的线程池thread_pool。在需要调用阻塞函数的协程call_blocking种,使用thread_pool.submit调用阻塞函数,并通过yield返回。这样便不会阻塞协程所在的线程的继续执行,也保证了阻塞函数前后代码的执行顺序。

4、在协程中等待多个异步调用

到目前为止,我们知道了协程中一个yield关键字等待一个异步调用的编程方法。其实,Tornado允许在协程中用一个yield关键字等待多个异步调用,只需要把这些调用以列表(list)或字典(dictionary)的方式传递给yield关键字即可。
实例:使用列表方式传递多个异步调用

1

2

3

4

5

6

7

8

9

10

11

12

13

#使用列表方式传递多个异步调用

from tornado import gen  #引入协程库gen

from tornado.httpclient import AsyncHTTPClient

 

@gen.coroutine   #使用gen.coroutine修饰器

def coroutine_visit():

    http_client=AsyncHTTPClient()

    list_response=yield [

        http_client.fetch("http://www.baidu.com"),

        http_client.fetch("http://www.api.jiutouxiang.com")

    ]

    for response in list_response:

        print(response.body)

在代码中仍然使用@gen.coroutine装饰器定义协程,在需要yield的地方用列表传递若干个异步调用,只有在列表种的所有调用都执行完成后,yield才会返回并且继续执行。yield以列表方式返回调用结果。

实例:用字典方式传递多个异步调用:

1

2

3

4

5

6

7

8

9

10

11

12

#使用列表方式传递多个异步调用

from tornado import gen  #引入协程库gen

from tornado.httpclient import AsyncHTTPClient

 

@gen.coroutine   #使用gen.coroutine修饰器

def coroutine_visit():

    http_client=AsyncHTTPClient()

    dict_response=yield {

       "baidu": http_client.fetch("http://www.baidu.com"),

        "9siliao":http_client.fetch("http://www.api.jiutouxiang.com")

    }

    print(dict_response["baidu"].body)

以上就是Python中Tornado协程的使用详解(附实例)的详细内容,更多文章请关注木庄网络博客!!

返回前面的内容

相关阅读 >>

Python文件打开的访问模式有哪些?

Python中对list去重的几种方法

Python中的int是什么意思

Python ide之pycharm中的快捷键总结

Python中的内置函数分享

关于Python中legb与闭包以及装饰器的具体讲解

Python列表元素如何求和

Python怎么增加矩阵维度

vscode下好用的Python插件及配置_Python

Python中str.format()详解_Python

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...