pytest - 多线程提速

python 复制代码
import time

def test1_test1():
    time.sleep(1)

    assert 1 == 1, "1==1"


def test1_test2():
    time.sleep(1)

    assert 1 == 1, "1==1"

上面2个函数,执行情况:

  • 正常执行时,花费 2.08s
  • 2个进程执行时,花费 1.18s
  • 2个线程执行时,花费 1.15s

问题:python有GIL(全局解释器锁),同一时刻只能执行一条线程的字节码指令,那么为什么pytest执行用例时,多线程会加快执行速度?

暂时得到的答案:time sleep 属于IO bound的任务。在IO bound的时候切换CPU去执行其他的字节码

相关推荐
Attachment George5 分钟前
山东大学软件学院-项目实训-个人开发日志(十):材料问答链路开发——文档解析、OCR兜底与持续追问完善
python·ai·langchain·kotlin·rag
码云骑士6 分钟前
24-Django请求全链路-WSGI到数据库响应的完整旅程
数据库·python·django
贺国亚14 分钟前
06-奢侈零售VIP-Clienteling-Agent
开发语言·python·零售
knighthood200115 分钟前
鸿蒙PC迁移:jieba 中文分词 Python 三方库鸿蒙PC适配全记录
python·中文分词·harmonyos
nix.gnehc19 分钟前
Python 内存管理深度解析
开发语言·python
knight_9___30 分钟前
AI Agent 是什么?
人工智能·python·agent·rag·mcp
Cloud_Shy61837 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第七章 Item 51)
开发语言·人工智能·笔记·python·学习方法
nix.gnehc38 分钟前
Python 并发深度解析
服务器·开发语言·python
Volunteer Technology44 分钟前
Flink 时间、窗口及操作(二)
java·python·flink
老徐聊GEO1 小时前
2026年:巧妙引导,让AI回答中自然融入你的品牌
大数据·人工智能·python