目录
一、资源共享、全局变量和资源竞争
1、资源共享
下图读取只读到0的原因是当写入的时候睡眠了0.2s,这时,读取的函数rdate()就直接读取

想要读取正常,可在wd.start()后加:time.sleep(1)或wd.join()

2、全局变量和资源竞争

b的值如果比较小,没有资源竞争的问题;值大的话计算机计算不过来,延长时间更明显。

二、线程的同步
1、线程的同步方式
- 线程等待join
- 互斥锁
2、同步的概念
有两个线程,线程A写入,线程B读取线程A写入的值,线程A先写入,线程B才能读取;线程A、B之间就是一种同步关系。
线程同步:主线程和创建的子线程之间各自执行完自己的代码直到结束。
3、互斥锁
-
概念
保证多个线程间共享数据不会出现数据错误问题;保证同一时刻只能有一个线程去操作。
-
使用方法
threading模块里面定义了Lock函数,通过调用这个函数可以获取到一把互斥锁。
acquire()——加锁 和 release()——解锁:这两个方法必须成对出现,不然会造成死锁现象。
死锁:一直等待对方释放锁的情况就是死锁。会造成应用的停止响应,不能处理其他任务了。
注意:使用互斥锁的时候要再合适的地方释放锁。

三、执行的任务有参数
通过args=() 向任务传入参数

本文探讨了资源共享中的线程行为,特别是如何避免数据竞争。讲解了线程同步的关键概念,如互斥锁的使用方法,以及如何通过参数传递实现任务定制。了解这些技巧有助于编写高效且并发安全的多线程程序。
50

被折叠的 条评论
为什么被折叠?



