互斥锁创建以及优缺点

加锁:互斥锁
当多线程几乎同时修改某一个共享参数时就需要同步控制
锁的状态:锁定/非锁定
在threading模块下面有一个Lock类,可以方便的锁定使用

1创建
Mutex=threadingf.Lock()
2锁定
Mutex.acquire([blocking])
3解锁
Mutex.release()
Blocking设置为True则线程阻塞,知道获取到这个锁为止
锁将并行操作变为串行操作

from  threading import Thread
from  threading import Lock
g_num=0
def worke1():
    global g_num
    for i in range(1000000):
        mutex.acquire()  # 加锁
        g_num+=1
        mutex.release()
def worke2():
    global g_num
    for i in range(1000000):
        mutex.acquire()
        g_num += 1
        mutex.release()
mutex=Lock()#创建锁
if __name__ == '__main__':
    t1=Thread(target=worke1)
    t2=Thread(target=worke2)
    t1.start()
    t2.start()
    t1.join()
    t2.join()
    print('值为',g_num)

总结 锁的好处:
1 确保了某段关键代码只能由一个线程从头到尾的完成的执行
2 阻止了多线程并发执行,包含锁的某段代码实际上只能以单线程模式执行
3 由于可以存在多个锁,不同的线程持有有不同的锁,并试图获取对方持有的锁时,可能会造成死锁。

死锁:
例子: 两个线程(线程1是你,线程2是老婆),做菜
资源:锅,馋
抄两个菜,你们两个各炒一个
解决方法
1尽量减少资源占用时间,可以降低死锁的发生的概率
2银行家算法

总结:
功能:多线程和多进程都能完成多任务开发
进程是系统进行资源分配和调度的一个独立单位
线程是进程的一个实体,是CPU调度和分配的基本单位,线程是比进程更小的能够独立运行的基本单位
线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源,(如程序计算器,一组寄存器和栈),他是可以与同一进程当中其他线程共享锁拥有的全部资源。
小结1一个程序至少有一个进程,一个进程至少有一个线程
2 线程是划分尺度较小的进程(资源占用少),使得多线程程序的并发性高
3进程执行过程中
4,线程不能独立执行,必须依存在进程中、。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值