python解释器锁GIL

这篇博客探讨了计算密集型和IO密集型任务的区别,指出在处理计算密集型任务时,多进程比多线程更优。由于Python的全局解释器锁(GIL),多线程在CPU资源竞争中受限。文章提供了通过使用多进程、C扩展和分布式计算来绕过GIL的方法,并展示了Python中使用多进程进行网络请求的代码示例。
  • 计算密集型

    主要占用CPU资源
    
  • IO密集型

    IO就是Input output,需要等待一些任务
     	网络请求会有网络延迟
     	和数据库交互需要等待数据库查询事件
     	读写硬盘
    
  • 多进程在处理计算密集型程序的时候比多线程快

     由于全局解释器锁的存在,一个进程下,只允许一个线程执行python程序的字节码(当前代码的二进制表示)。
     简单的说,创建的10个线程其实在争夺一个cpu资源,但是遇到IO操作会读CPU资源。
    
  • 如何绕过GIL?

     将多线程方法改为多进程
     将计算密集型任务转移给C扩展。
     分布式计算引擎spark,Apache
     使用PyPy解释器,工业上几乎没人这么用,因为PyPy并不成熟。
    

代码:

import time
import requests
from multiprocessing import Process
result = []
print(f"主进程result内存地址:{id(result)}")

def request_baidu(index):
    time.sleep(2)
    url = "https://www.baidu.com/"
    body = ""
    headers={
        "User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/101.0.4951.64 Safari/537.36 Edg/101.0.1210.53"
    }
    response = requests.get(url=url,headers=headers)
    print(f"当前请求序号:{index},返回结果状态码:{response.status_code}")
    print(f"子进程result内存地址:{id(result)}")
    result.append(response)

if __name__ == '__main__':
    process_array = []
    for i in range(10):
        p = Process(target=request_baidu,args= (i, ))
        process_array.append(p)
        p.start()
    for p in process_array:
        p.join()
    print("done!")

打印结果:
在这里插入图片描述

多源动态最优潮流的分布鲁棒优化方法(IEEE118节点)(Matlab代码实现)内容概要:本文介绍了基于Matlab代码实现的多源动态最优潮流的分布鲁棒优化方法,适用于IEEE118节点电力系统。该方法结合两阶段鲁棒模型确定性模型,旨在应对电力系统中多源不确定性(如可再生能源出力波动、负荷变化等),提升系统运行的安全性经济性。文档还列举了大量相关的电力系统优化研究案例,涵盖微电网调度、电动汽车集群并网、需求响应、配电网重构等多个方向,并提供了YALMIP等工具包的网盘下载链接,支持科研复现进一步开发。整体内容聚焦于电力系统建模、优化算法应用及鲁棒性分析。; 适合人群:具备电力系统基础知识和Matlab编程能力的研究生、科研人员及从事能源系统优化的工程技术人员;熟悉优化建模(如鲁棒优化、分布鲁棒优化)者更佳。; 使用场景及目标:①开展电力系统动态最优潮流研究,特别是含高比例可再生能源的场景;②学习和复现分布鲁棒优化在IEEE118等标准测试系统上的应用;③进行科研项目开发、论文复现或算法比较实验;④获取相关Matlab代码资源仿真工具支持。; 阅读建议:建议按文档结构逐步浏览,重点关注模型构建思路代码实现逻辑,结合提供的网盘资源下载必要工具包(如YALMIP),并在Matlab环境中调试运行示例代码,以加深对分布鲁棒优化方法的理解应用能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值