0

0

Python 并发模型详解及面试常见问题

舞夢輝影

舞夢輝影

发布时间:2026-03-01 19:16:01

|

123人浏览过

|

来源于php中文网

原创

python 并发模型详解及面试常见问题

Python 的 GIL 是什么,它如何影响并发

CPython 解释器中存在一个全局解释器锁(GIL),它确保同一时刻只有一个线程执行 Python 字节码。这意味着多线程在 CPU 密集型任务中无法真正并行,只能交替执行;但对 I/O 密集型任务影响较小,因为线程在等待 I/O 时会主动释放 GIL。

关键点:

  • GIL 是 CPython 特有,PyPy、Jython 等实现没有 GIL
  • 不能靠多线程提升 CPU 密集型程序性能,应优先考虑 多进程(multiprocessing)异步(asyncio)
  • 可通过 ctypes 调用 C 扩展绕过 GIL,但需手动管理线程安全

threading、multiprocessing 和 asyncio 怎么选

三者适用场景差异明显,选错会导致性能下降或逻辑错误:

  • threading:适合 I/O 密集型且需共享内存的场景,如多个 HTTP 请求 + 共享缓存字典;注意用 LockRLock 保护临界区
  • multiprocessing:适合 CPU 密集型任务,或需彻底隔离状态的场景;进程间通信靠 QueuePipeManager,开销比线程大
  • asyncio:适合高并发 I/O(如 Web 服务、爬虫、实时消息),单线程内协程协作式调度;必须所有 I/O 操作都用 async/await 版本(如 aiohttp 而非 requests

asyncio 中 event loop 是怎么工作的

event loop 是 asyncio 的核心调度器,负责注册、等待和执行协程、回调、Future 等对象。它本质是一个运行在单线程中的无限循环,不断检查哪些 I/O 事件就绪(如 socket 可读/可写),然后调用对应回调或恢复挂起的协程。

Kuwebs企业网站管理系统3.1.5 UTF8
Kuwebs企业网站管理系统3.1.5 UTF8

酷纬企业网站管理系统Kuwebs是酷纬信息开发的为企业网站提供解决方案而开发的营销型网站系统。在线留言模块、常见问题模块、友情链接模块。前台采用DIV+CSS,遵循SEO标准。 1.支持中文、英文两种版本,后台可以在不同的环境下编辑中英文。 3.程序和界面分离,提供通用的PHP标准语法字段供前台调用,可以为不同的页面设置不同的风格。 5.支持google地图生成、自定义标题、自定义关键词、自定义描

下载

立即学习Python免费学习笔记(深入)”;

常见误区:

  • asyncio.run() 每次调用都会新建一个 event loop,不能在已有 loop 中重复调用
  • 阻塞操作(如 time.sleep()、普通数据库驱动)会让整个 loop 卡住,必须用 asyncio.sleep()loop.run_in_executor() 托管到线程池
  • 协程函数本身不执行,只有被 await 或提交给 loop 后才启动

面试常问的并发陷阱与调试技巧

面试官常通过具体问题考察对并发本质的理解,而非 API 记忆:

  • 竞态条件示例:两个线程同时执行 counter += 1(非原子),结果可能少于预期;修复方式不是加锁万能,而是优先考虑无状态设计或使用 queue.Queue 做任务分发
  • 死锁排查:用 threading.set_trace()faulthandler 捕获线程堆栈;避免嵌套锁,按固定顺序获取多个锁
  • asyncio 误用:在协程里直接调用同步函数、忘记 await、在非主线程启动 loop —— 这些都会导致静默失败或 RuntimeError
  • 性能定位:用 concurrent.futures.ProcessPoolExecutor 替换 threading 测试是否为 CPU 瓶颈;用 aiomonitortrio 的调试模式观察协程生命周期

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

429

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

723

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

372

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

27

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

25

2026.01.21

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

24

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号