栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Python: 多线程与互斥锁

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Python: 多线程与互斥锁

目录

一、在 Python 使用多线程

二、互斥锁&防止死锁


一、在 Python 使用多线程
import threading
import time
import random

class MyThread(threading.Thread):
    def __init__(self, name, mutex, arg):
        threading.Thread.__init__(self, daemon=True)
        self.name = name
        self.mutex = mutex
        self.arg = arg

    def log(self, msg):
        print("{0} - {1} - {2}".format(self.name, time.time(), msg))

    def sleep(self):
        time.sleep(random.randint(1, 5))

    def run(self):
        for i in range(10):
            self.log("do something")
            self.sleep()

        self.mutex.acquire()
        self.arg['count'] = self.arg.get('count', 0) + 1
        self.mutex.release()


def test_thread():
    mutex = threading.Lock()
    arg = dict()
    arg['count'] = 0
    for i in range(10):
        t = MyThread(str(i), mutex, arg)
        t.start()
    while True:
        if arg.get('count', 0) >= 10:
            break
        time.sleep(0.5)
    print("end and exit")

if "__main__" == __name__:
    test_thread()

二、互斥锁&防止死锁

上述代码中,self.mutex.acquire() 就是在加锁,self.mutex.release() 就是在释放锁。

如果在加锁和释放锁的中间代码中,可能会抛出异常,那么可能导致互斥锁被死锁。此时可以使用下面的代码加以保护:

try:
    mutex.acquire()
    # some code mybe raise exception
except Exception as e:
    print(e)    
finally:
    mutex.release()

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/588823.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号