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

python并发编程之多线程和多进程

了解过python 编程语言的人,可能很多人都听过,python的多线程是假的。

之所以这么说的原因是因为,大家应该都知道python 是一门解释型语言,在cpython解释器中有一个GIL(Global Interpreter Lock),全局解释锁,它是一把全局锁,作用在python解释器上。

它的作用就是让CPU同时只能执行一个python线程,也就是说python并发编程失去了意义。

而之所以有GIL的存在,是因为python语言使用了大量的c语言库,GIL是为了解决引入C语言库的并发问题,并且因为使用的是单锁,因此也排除了死锁的问题。

cpython使用的是引用计数的方式解决垃圾回收的问题,因此为了防止其它线程更改计数参数,因此才有了GIL,如果使用的是其它的垃圾回收方式,那么就不会有GIL的问题。

怎么解决python的GIL功能呢?

GIL功能并不是完全一无是处,它在CPU密集型的任务中,因为单线程问题会导致python并发失去意义,但在IO密集型的任务中,因为不需要使用CPU的多核优势,因此多线程依然有其作用。

原因是因为IO任务,python线程进入等待,python解释器会释放GIL。

如果在CPU密集型的任务中,可以使用python多进程实现并发任务,原因就是python每个进程都会有一个自己的解释器,这时不同的解释器之间无法干涉,因此多进程就实现多线程的效果;但由于创建进程会比创建线程消耗更多的资源,因此多进程会对服务器造成更大的压力。

还有一个办法就是使用Python协程,其也可以解决并发问题。

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

相关文章:

  • gorm入门——根据条件查询列表
  • 笔面试编程题总结
  • [other][知识]八大行星的英文各是什么?
  • 如何使用 AWS CLI 创建和运行 EMR 集群
  • HDFS写入数据的流程图
  • 【Material-UI】使用指南:快速入门与核心功能解析
  • 【Java 第十三篇章】MyBatis 持久化框架的介绍
  • AI新应用:概要设计与详细设计自动生成解决方案
  • 【物联网设备端开发】使用QEMU模拟ESP硬件运行ESP-IDF
  • #子传父父传子props和emits #封装的table #vue3
  • 尚硅谷谷粒商城项目笔记——四、使用docker安装redis【电脑CPU:AMD】
  • Java在无人驾驶方向的就业方向
  • 机器学习中的关键距离度量及其应用
  • Redis中缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题
  • 【C++】vector 的模拟实现
  • 【C++】模版详解
  • 应用商店故障(UOS系统)
  • 8月8号前端日报:web在线进行eps32固件升级
  • win7安装python3.10
  • 【Liunx】线程与进程的经典面试题总结
  • Python中的 `break` 语句:掌握循环控制的艺术
  • ES2023(ES14)新特性有什么?
  • Linux 中的特殊文件权限:SUID、GUID 和 Sticky
  • 2024 某公司python 面试真题
  • jwt伪造身份组组组合拳艰难通关
  • leetcode日记(64)最小覆盖子串
  • C语言——编译与链接
  • 你一定想看的LVS详细介绍及常见模式(NAT,DR,防火墙标记)实验详解
  • 嵌入式初学-C语言-十七
  • leetcode数论(2280. 表示一个折线图的最少线段数)-几何