mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-25 23:11:02 +08:00
PUB: 20160917 A Web Crawler With asyncio Coroutines.md
https://linux.cn/article-8265-1.html 等陆续三篇 @qingyunha
This commit is contained in:
parent
dc622bc579
commit
aa6e6d9466
@ -646,7 +646,7 @@ StopIteration
|
|||||||
rv = yield from gen
|
rv = yield from gen
|
||||||
```
|
```
|
||||||
|
|
||||||
前面我们批评过基于回调的异步编程模式,其中最大的不满是关于 “stack ripping”:当一个回调抛出异常,它的堆栈回溯通常是毫无用处的。它只显示出事件循环运行了它,而没有说为什么。那么协程怎么样?
|
前面我们批评过基于回调的异步编程模式,其中最大的不满是关于 “堆栈撕裂(stack ripping)”:当一个回调抛出异常,它的堆栈回溯通常是毫无用处的。它只显示出事件循环运行了它,而没有说为什么。那么协程怎么样?
|
||||||
|
|
||||||
```python
|
```python
|
||||||
>>> def gen_fn():
|
>>> def gen_fn():
|
||||||
@ -1019,7 +1019,7 @@ loop.run_until_complete(self.crawler.crawl())
|
|||||||
|
|
||||||
程序如何结束?因为 `crawl` 是一个生成器函数,调用它返回一个生成器。为了驱动它,asyncio 把它包装成一个 task:
|
程序如何结束?因为 `crawl` 是一个生成器函数,调用它返回一个生成器。为了驱动它,asyncio 把它包装成一个 task:
|
||||||
|
|
||||||
|
```python
|
||||||
class EventLoop:
|
class EventLoop:
|
||||||
def run_until_complete(self, coro):
|
def run_until_complete(self, coro):
|
||||||
"""Run until the coroutine is done."""
|
"""Run until the coroutine is done."""
|
Loading…
Reference in New Issue
Block a user