一、同步与异步的概念
- 前言 python由于GIL(全局锁)的存在,不能发挥多核的优势,其性能一直饱受诟病。然而在IO密集型的网络编程里,异步处理比同步处理能提升成百上千倍的效率
- 同步 指完成事务的逻辑,先执行第一个事务,如果阻塞了,会一直等待,直到这个事务完成,再执行第二个事务,顺序执行
- 异步 是和同步相对的,异步是指在处理调用这个事务的之后,不会等待这个事务的处理结果,直接处理第二个事务去了,通过状态、通知、回调来通知调用者处理结果
- 说明 假设用户访问一个网站并得到响应的时间为5秒,使用同步思想则一共需要20秒以上,那么使用异步思想则一共需要5秒左右
二、同步与异步代码
同步
<span class="hljs-keyword">import</span> time
<span class="hljs-function"><span class="hljs-keyword">def</span> <span class="hljs-title">run</span><span class="hljs-params">(index)</span>:</span>
print(<span class="hljs-string">"sunck is a good man"</span>, index)
time.sleep(<span class="hljs-number">2</span>)
print(<span class="hljs-string">"sunck is a nice man"</span>, index)
<span class="hljs-keyword">for</span> i <span class="hljs-keyword">in</span> range(<span class="hljs-number">1</span>, <span class="hljs-number">6</span>):
run(i)
异步
说明:后面的课程中会使用到asyncio模块,现在的目的是使同学们理解异步思想
<span class="hljs-keyword">import</span> asyncio
<span class="hljs-keyword">import</span> time<span class="hljs-comment"># 定义一个异步函数(定义了一个协程)</span>
<span class="hljs-keyword">async</span> <span class="hljs-function"><span class="hljs-keyword">def</span> <span class="hljs-title">run</span><span class="hljs-params">()</span>:</span>
print(<span class="hljs-string">"sunck is a good man"</span>)
<span class="hljs-comment">#模拟一个耗时IO</span>
asyncio.sleep(<span class="hljs-number">2</span>)
print(<span class="hljs-string">"sunck is a nice man"</span>)
loop = asyncio.get_event_loop()
<span class="hljs-keyword">for</span> i <span class="hljs-keyword">in</span> range(<span class="hljs-number">1</span>, <span class="hljs-number">5</span>):
loop.run_until_complete(run())