Python协程是用户态轻量级执行单元,由解释器在单线程内调度,通过await暂停恢复实现协作式并发;线程是操作系统内核管理的执行实体,依赖抢占式调度和GIL。
Python 协程不是线程,它和线程是两种不同层次的并发模型,既不依赖线程,也不等价于线程。
协程由 Python 解释器(或 asyncio 等库)在单个线程内调度,不涉及操作系统线程切换。它通过 暂停(await) 和 恢复(yield from / await) 来实现协作式并发,所有协程共享同一个线程的栈空间和上下文。

线程由操作系统调度,有独立的栈、寄存器状态和内核资源(如信号掩码、TLS)。CPython 中多线程受 GIL 限制,无法真正并行执行 CPU 密集型任务。
asyncio 提供了 loop.run_in_executor(),允许把阻塞操作(如文件读写、CPU 密集计算)提交给线程池或进程池执行,避免阻塞事件循环。
线程是“操作系统分出来的执行流”,协程是“程序员用 async/await 写出来的可挂起函数”;线程靠抢占式调度,协程靠显式 await 让出控制权;线程解决的是“谁来跑”,协程解决的是“怎么高效地跑一堆 IO 等待任务”。