电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

互斥鎖解決 Python 中多線程共享全局變量的問題(推薦)

瀏覽:2日期:2022-07-09 16:44:21

一、同步概念

同步就是協同步調,按預定的先后次序進行運行。如:你說完,我再說。

'同'字從字面上容易理解為一起動作。

其實不是,在這里,'同'字應是指協同、協助、互相配合。

線程同步,可理解為線程A和B一塊配合,A執行到一定程度時要依靠B的某個結果,于是停下來,示意B運行;B執行,再將結果給A;A再繼續操作。

之前我們遇到過,如果多個線程共同對某個數據修改,則可能出現不可預料的結果,為了保證數據的正確性,需要對多個線程進行同步。

解決線程同時修改全局變量的方式

我們先把上次那個問題再看下。

import threadingimport timeg_num = 0def work1(num): global g_num for i in range(num): g_num += 1 print('----in work1, g_num is %d---' % g_num)def work2(num): global g_num for i in range(num): g_num += 1 print('----in work2, g_num is %d---' % g_num)print('---線程創建之前g_num is %d---' % g_num)t1 = threading.Thread(target=work1, args=(1000000,))t1.start()t2 = threading.Thread(target=work2, args=(1000000,))t2.start()# 確保子線程都運行結束while len(threading.enumerate()) != 1: time.sleep(1)print('2個線程對同一個全局變量操作之后的最終結果是:%s' % g_num)

運行結果:

---線程創建之前g_num is 0-------in work2, g_num is 1048576-------in work1, g_num is 1155200---2個線程對同一個全局變量操作之后的最終結果是:1155200

對于這個計算錯誤的問題,可以通過線程同步來進行解決。

思路,如下:

系統調用 t1,然后獲取到 g_num 的值為0,此時上一把鎖,即不允許其他線程操作 g_num。

t1 對 g_num 的值進行+1。

t1 解鎖,此時 g_num 的值為1,其他的線程就可以使用 g_num 了,而且 g_num 的值不是0而是1。

同理其他線程在對 g_num 進行修改時,都要先上鎖,處理完后再解鎖,在上鎖的整個過程中不允許其他線程訪問,就保證了數據的正確性。

思路基本是這個樣子,那代碼怎么來實現呢?

二、互斥鎖解決資源競爭的問題

當多個線程幾乎同時修改某一個共享數據的時候,需要進行同步控制。

線程同步能夠保證多個線程安全訪問競爭資源,最簡單的同步機制就是引入互斥鎖。

互斥鎖為資源引入一個狀態:鎖定/非鎖定。

某個線程要更改共享數據時,先將其鎖定,此時資源的狀態為“鎖定”,其他線程不能更改;直到該線程釋放資源,將資源的狀態變成“非鎖定”,其他的線程才能再次鎖定該資源。

互斥鎖保證了每次只有一個線程進行寫入操作,從而保證了多線程情況下數據的正確性。

互斥鎖解決 Python 中多線程共享全局變量的問題(推薦)

threading 模塊中定義了 Lock 類,可以方便的處理鎖定:

# 創建鎖mutex = threading.Lock()# 鎖定mutex.acquire()# 釋放mutex.release()

注意:

如果這個鎖之前是沒有上鎖的,那么 acquire 不會堵塞。

如果在調用 acquire 對這個鎖上鎖之前,它已經被其他線程上了鎖,那么此時 acquire 會堵塞,直到這個鎖被解鎖為止。

示例:

使用互斥鎖完成2個線程對同一個全局變量各加100萬次的操作。

import threadingimport timeg_num = 0def test1(num): global g_num for i in range(num): mutex.acquire() # 上鎖 g_num += 1 mutex.release() # 解鎖 print('---test1---g_num=%d' % g_num)def test2(num): global g_num for i in range(num): mutex.acquire() # 上鎖 g_num += 1 mutex.release() # 解鎖 print('---test2---g_num=%d' % g_num)# 創建一個互斥鎖# 默認是未上鎖的狀態mutex = threading.Lock()# 創建2個線程,讓他們各自對g_num加1000000次p1 = threading.Thread(target=test1, args=(1000000,))p1.start()p2 = threading.Thread(target=test2, args=(1000000,))p2.start()# 等待計算完成while len(threading.enumerate()) != 1: time.sleep(1)print('2個線程對同一個全局變量操作之后的最終結果是:%s' % g_num)

運行結果:

---test1---g_num=1989108---test2---g_num=20000002個線程對同一個全局變量操作之后的最終結果是:2000000

可以看到最后的結果,加入互斥鎖后,其結果與預期相符。

記住,上鎖的代碼范圍要越小越好。在業務邏輯正確的前提下,能鎖一行代碼,就不要鎖兩行。

上鎖解鎖過程

當一個線程調用鎖的 acquire() 方法獲得鎖時,鎖就進入“locked”狀態。

每次只有一個線程可以獲得鎖。

如果此時另一個線程試圖獲得這個鎖,該線程就會變為“blocked”狀態,稱為“阻塞”,直到擁有鎖的線程調用鎖的 release() 方法釋放鎖之后,鎖進入“unlocked”狀態。

線程調度程序從處于同步阻塞狀態的線程中選擇一個來獲得鎖,并使得該線程進入運行(running)狀態。

總結

鎖的好處:

確保了某段關鍵代碼只能由一個線程從頭到尾完整地執行。

鎖的壞處:

阻止了多線程并發執行,包含鎖的某段代碼實際上只能以單線程模式執行,效率就大大地下降了。

由于可以存在多個鎖,不同的線程持有不同的鎖,并試圖獲取對方持有的鎖時,可能會造成死鎖。

到此這篇關于互斥鎖解決 Python 中多線程共享全局變量的問題的文章就介紹到這了,更多相關Python 多線程共享全局變量內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | 耐酸泵,耐酸泵厂家-淄博华舜耐腐蚀真空泵 | 铸钢件厂家-铸钢齿轮-减速机厂家-淄博凯振机械有限公司 | 青岛空压机,青岛空压机维修/保养,青岛空压机销售/出租公司,青岛空压机厂家电话 | 小青瓦丨古建筑瓦丨青瓦厂家-宜兴市徽派古典建筑材料有限公司 | 亿诺千企网-企业核心产品贸易 | 阿尔法-MDR2000无转子硫化仪-STM566 SATRA拉力试验机-青岛阿尔法仪器有限公司 | 企业彩铃制作_移动、联通、电信集团彩铃上传开通_彩铃定制_商务彩铃管理平台-集团彩铃网 | 合肥办公室装修 - 合肥工装公司 - 天思装饰| 彩超机-黑白B超机-便携兽用B超机-多普勒彩超机价格「大为彩超」厂家 | 创富网-B2B网站|供求信息网|b2b平台|专业电子商务网站 | 喷砂机厂家_自动除锈抛丸机价格-成都泰盛吉自动化喷砂设备 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 渣土车电机,太阳能跟踪器电机,蜗轮蜗杆减速电机厂家-淄博传强电机 | 示波器高压差分探头-国产电流探头厂家-南京桑润斯电子科技有限公司 | 诚暄电子公司首页-线路板打样,pcb线路板打样加工制作厂家 | 悬浮拼装地板_篮球场木地板翻新_运动木地板价格-上海越禾运动地板厂家 | 陶氏道康宁消泡剂_瓦克消泡剂_蓝星_海明斯德谦_广百进口消泡剂 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 博博会2021_中国博物馆及相关产品与技术博览会【博博会】 | 德州网站制作 - 网站建设设计 - seo排名优化 -「两山建站」 | 蔬菜清洗机_环速洗菜机_异物去除清洗机_蔬菜清洗机_商用洗菜机 - 环速科技有限公司 | 工业CT-无锡璟能智能仪器有限公司 | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 德州网站开发定制-小程序开发制作-APP软件开发-「两山开发」 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 定量包装秤,吨袋包装称,伸缩溜管,全自动包装秤,码垛机器人,无锡市邦尧机械工程有限公司 | 沈阳网站建设_沈阳网站制作_沈阳网页设计-做网站就找示剑新零售 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 海水晶,海水素,海水晶价格-潍坊滨海经济开发区强隆海水晶厂 | 山东活动策划|济南活动公司|济南公关活动策划-济南锐嘉广告有限公司 | 沈阳真空机_沈阳真空包装机_沈阳大米真空包装机-沈阳海鹞真空包装机械有限公司 | 清洁设备_洗地机/扫地机厂家_全自动洗地机_橙犀清洁设备官网 | 产业规划_产业园区规划-产业投资选址及规划招商托管一体化服务商-中机院产业园区规划网 | 玉米深加工设备-玉米深加工机械-新型玉米工机械生产厂家-河南粮院机械制造有限公司 | 福州仿石漆加盟_福建仿石漆厂家-外墙仿石漆加盟推荐铁壁金钢(福建)新材料科技有限公司有保障 | 上海刑事律师|刑事辩护律师|专业刑事犯罪辩护律师免费咨询-[尤辰荣]金牌上海刑事律师团队 | 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 东莞市海宝机械有限公司-不锈钢分选机-硅胶橡胶-生活垃圾-涡电流-静电-金属-矿石分选机 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | BOE画框屏-触摸一体机-触控查询一体机-触摸屏一体机价格-厂家直销-触发电子 | 深圳诚暄fpc首页-柔性线路板,fpc柔性线路板打样生产厂家 |