该图展示了泡茶的几个步骤。
同步和异步,与华罗庚的《统筹方法》道理是一样的。
《统筹方法》小学课本链接:统筹方法--华罗庚 (小学语文) - zbuhui - 博客园 (cnblogs.com)
结论
- 同步:所有任务按顺序进行,一个任务完成才能开始下一个,导致浪费大量时间在等待上。
- 异步:任务可以同时进行,不必等待,明显减少总时间。
同步
定义:同步执行是指每个任务按顺序进行,一个任务必须等待前一个任务完成后才能开始。
同步泡茶流程:
- 先洗开水壶(1分钟)。
- 洗完水壶后开始烧开水(15分钟)。在等待开水烧开的这15分钟里,其他任务无法进行。
- 烧水的同时不能进行其他步骤,所以烧完水后再洗茶壶(1分钟)。
- 接着洗茶杯(2分钟)。
- 最后拿茶叶(1分钟)。
总时间: 1 + 15 + 1 + 2 + 1 = 20分钟
在同步模式下,很多时间都浪费在等待上。例如,烧水需要15分钟,在这段时间内其他工作都被阻塞了,导致总时间较长。
异步
定义:异步执行是指任务可以并行进行,不必等待前一个任务完成。当一个任务在等待时,可以执行其他任务。
异步泡茶流程:
- 先洗开水壶(1分钟)。
- 洗完开水壶后开始烧开水(15分钟),这时可以进行其他操作。
- 同时洗茶壶(1分钟),洗茶杯(2分钟),拿茶叶(1分钟)。
总时间: 16分钟(烧水时间,同时完成其他所有任务)
在异步模式下,通过合理安排任务并行执行,可以显著减少总时间,避免不必要的等待时间。
示例
同步代码示例
import time
def task(name):
print(f"开始任务 {name}")
time.sleep(2) # 模拟任务需要2秒钟
print(f"完成任务 {name}")
def main_sync():
for i in range(1, 4):
task(f"同步任务 {i}")
if __name__ == "__main__":
start_time = time.time()
main_sync()
end_time = time.time()
print(f"同步执行总时间: {end_time - start_time:.2f} 秒")
输出:
开始任务 同步任务 1
完成任务 同步任务 1
开始任务 同步任务 2
完成任务 同步任务 2
开始任务 同步任务 3
完成任务 同步任务 3
同步执行总时间: 6.00 秒
异步代码示例
import asyncio
async def task(name):
print(f"开始任务 {name}")
await asyncio.sleep(2) # 模拟任务需要2秒钟
print(f"完成任务 {name}")
async def main_async():
tasks = [task(f"异步任务 {i}") for i in range(1, 4)]
await asyncio.gather(*tasks)
if __name__ == "__main__":
start_time = time.time()
asyncio.run(main_async())
end_time = time.time()
print(f"异步执行总时间: {end_time - start_time:.2f} 秒")
输出:
开始任务 异步任务 1
开始任务 异步任务 2
开始任务 异步任务 3
完成任务 异步任务 1
完成任务 异步任务 2
完成任务 异步任务 3
异步执行总时间: 2.00 秒