资源共享、全局变量和资源竞争
资源共享
下图读取只读到0的原因是当写入的时候睡眠了0.2s,这时,读取的函数rdate()就直接读取。
想要读取正常,可在wd.start()后加:time.sleep(1)或wd.join()
全局变量和资源竞争
b的值如果比较小,没有资源竞争的问题;值大的话计算机计算不过来,延长时间更明显。
线程的同步
同步方式
- 线程等待join
- 互斥锁
同步的概念
有两个线程,线程A写入,线程B读取线程A写入的值,线程A先写入,线程B才能读取;线程A、B之间就是一种同步关系。
线程同步:主线程和创建的子线程之间各自执行完自己的代码直到结束。
互斥锁
概念
保证多个线程间共享数据不会出现数据错误问题;保证同一时刻只能有一个线程去操作。
使用方法
threading模块里面定义了Lock函数,通过调用这个函数可以获取到一把互斥锁。
acquire()——加锁 和 release()——解锁:这两个方法必须成对出现,不然会造成死锁现象。
死锁:一直等待对方释放锁的情况就是死锁。会造成应用的停止响应,不能处理其他任务了。
注意:使用互斥锁的时候要再合适的地方释放锁
执行的任务有参数
通过args=() 向任务传入参数