asyncio的默认调度器是公平的。默认情况下,asyncio使用的是基于事件循环的调度器,它会公平地分配CPU时间片给所有的协程任务。
下面是一个代码示例来验证这一点:
import asyncio
async def task(name, delay):
print(f'Task {name} started')
await asyncio.sleep(delay)
print(f'Task {name} completed')
async def main():
tasks = [
asyncio.create_task(task('A', 1)),
asyncio.create_task(task('B', 2)),
asyncio.create_task(task('C', 3))
]
await asyncio.gather(*tasks)
asyncio.run(main())
在上面的示例中,我们定义了三个异步任务task
,每个任务都会等待一段时间后完成。我们使用asyncio.create_task()
方法创建了这些任务,并将它们加入到事件循环中。
根据上面的代码,任务A的延迟时间最短(1秒),任务C的延迟时间最长(3秒)。但是,由于默认调度器是公平的,它们会被公平地分配CPU时间片,因此任务A不会在任务C之前完成。
运行上述代码,可以观察到输出的顺序是公平的。输出可能类似于:
Task A started
Task B started
Task C started
Task A completed
Task B completed
Task C completed
可以看到,任务A、B和C的完成顺序与它们的延迟时间无关,这表明asyncio的默认调度器是公平的。