当前位置: 首页 > news >正文

python并发编程

一、程序提速的方法

在这里插入图片描述

二、python对并发编程的支持

  • 多线程:threading,利用CPU和IO可以同时执行的原理,让CPU不会干巴巴等待IO完成;
  • 多进程:multiprocess,利用多核CPU的能力,真正的并行执行任务;
  • 异步IO:asyncio,当线程比较多时,切换线程也会占用CPU资源,可在单线程中利用CPU和IO同时执行的原理,实现函数异步执行;
  • 使用Lock对资源加锁,防止冲突访问;
  • 使用Queue实现不同线程/进程之间的数据通信,实现生产者-消费者模式;
  • 使用线程池Pool/进程池Pool,简化线程/进程的任务提交,等待结果、获取结果;
  • 使用subprocess启动外部程序的进程,并进行输入输出交互;

三、python并发编程的三种方式

3.1 3种方式的区别和选择

多线程Thread,多进程Process,多协程Coroutine。
在这里插入图片描述
在这里插入图片描述

3.2 GIL

在这里插入图片描述

四、实战

4.1 多线程

在这里插入图片描述

http://www.lryc.cn/news/137622.html

相关文章:

  • 【面试题】:前端怎么实现权限设计及遇到的bug
  • Vue 2 插槽
  • Spring 容器启动耗时统计
  • 1. 优化算法学习
  • 再获荣誉丨通付盾WAAP解决方案获“金鼎奖”优秀金融科技解决方案
  • 【腾讯云 TDSQL-C Serverless 产品测评】“橡皮筋“一样的数据库『MySQL高压篇』
  • python http文件上传
  • Android学习之路(9) Intent
  • vue项目配置git提交规范
  • 影响交叉导轨运行速度的因素有哪些?
  • List转Map
  • ES:一次分片设计问题导致的故障
  • vue 简单实验 自定义组件 综合应用 传参数 循环
  • 【OpenCV实战】2.OpenCV基本数据类型实战
  • MyBatis进阶:告别SQL注入!MyBatis分页与特殊字符的正确使用方式
  • 安装Node(脚手架)
  • R语言10-R语言中的循环结构
  • 【Spring】一次性打包学透 Spring | 阿Q送书第五期
  • 第 7 章 排序算法(4)(插入排序)
  • JavsScript知识框架
  • el-input添加自定义指令只允许输入中文/英文/数字,兼容输入法事件
  • 0基础学习VR全景平台篇 第89篇:智慧眼-安放热点
  • java中用SXSSFWorkbook把多个list数据和单个实体dto导出到excel如何导出到多个sheet页详细实例?(亲测)
  • SpringBoot 01 如何创建 和pom的解析
  • axios详解
  • Docker分布式仓库
  • SQL注入之万能用户名
  • ubuntu20搭建环境使用的一下指令
  • GAN(生成对抗网络)
  • 实时同步ES技术选型:Mysql+Canal+Adapter+ES+Kibana