加锁:互斥锁
当多线程几乎同时修改某一个共享参数时就需要同步控制
锁的状态:锁定/非锁定
在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,线程不能独立执行,必须依存在进程中、。