【Python零基础入门篇 · 32】:资源共享、全局变量和资源竞争,线程的同步,执行的任务有参数

简介: 【Python零基础入门篇 · 32】:资源共享、全局变量和资源竞争,线程的同步,执行的任务有参数

资源共享、全局变量和资源竞争


资源共享


下图读取只读到0的原因是当写入的时候睡眠了0.2s,这时,读取的函数rdate()就直接读取


9b08d429c91b47139958ac39944fec89.png


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

fbeaca9a24fd4e2f88805817a57237c9.png




全局变量和资源竞争


0e519590579245f59b32e3e8245eaebb.png



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

69325501164b4f6d9c15ae1fd8c92783.png



线程的同步


同步方式


  • 线程等待join


  • 互斥锁




同步的概念


有两个线程,线程A写入,线程B读取线程A写入的值,线程A先写入,线程B才能读取;线程A、B之间就是一种同步关系。


线程同步:主线程和创建的子线程之间各自执行完自己的代码直到结束。



互斥锁


概念


保证多个线程间共享数据不会出现数据错误问题;保证同一时刻只能有一个线程去操作。


使用方法


threading模块里面定义了Lock函数,通过调用这个函数可以获取到一把互斥锁。

acquire()——加锁 和 release()——解锁:这两个方法必须成对出现,不然会造成死锁现象。


死锁:一直等待对方释放锁的情况就是死锁。会造成应用的停止响应,不能处理其他任务了。


   注意:使用互斥锁的时候要再合适的地方释放锁


581f70ee214f4990ab76fa98a9d4174a.png


执行的任务有参数


通过args=() 向任务传入参数


96badc2321314f4caa3a319ea2f28468.png

相关文章
|
2月前
|
缓存 负载均衡 Java
c++写高性能的任务流线程池(万字详解!)
本文介绍了一种高性能的任务流线程池设计,涵盖多种优化机制。首先介绍了Work Steal机制,通过任务偷窃提高资源利用率。接着讨论了优先级任务,使不同优先级的任务得到合理调度。然后提出了缓存机制,通过环形缓存队列提升程序负载能力。Local Thread机制则通过预先创建线程减少创建和销毁线程的开销。Lock Free机制进一步减少了锁的竞争。容量动态调整机制根据任务负载动态调整线程数量。批量处理机制提高了任务处理效率。此外,还介绍了负载均衡、避免等待、预测优化、减少复制等策略。最后,任务组的设计便于管理和复用多任务。整体设计旨在提升线程池的性能和稳定性。
80 5
|
4月前
|
前端开发 JavaScript 大数据
React与Web Workers:开启前端多线程时代的钥匙——深入探索计算密集型任务的优化策略与最佳实践
【8月更文挑战第31天】随着Web应用复杂性的提升,单线程JavaScript已难以胜任高计算量任务。Web Workers通过多线程编程解决了这一问题,使耗时任务独立运行而不阻塞主线程。结合React的组件化与虚拟DOM优势,可将大数据处理等任务交由Web Workers完成,确保UI流畅。最佳实践包括定义清晰接口、加强错误处理及合理评估任务特性。这一结合不仅提升了用户体验,更为前端开发带来多线程时代的全新可能。
85 1
|
4月前
|
存储 监控 Java
|
4月前
|
存储 Python
Python 中的局部变量和全局变量
【8月更文挑战第29天】
60 0
|
5月前
|
Python
Python中的全局变量和局部变量是什么?
在 Python 中, 全局变量与局部变量在作用域及访问权限上有着明显区别。全局变量在整个程序范围内均可访问, 如定义 `global_var` 并在函数 `func_using_global()` 内使用。局部变量仅在其定义的函数内有效, 如 `func_creating_local()` 中的 `local_var`, 在函数外访问会引发 `NameError`。
|
4月前
|
缓存 Java 容器
多线程环境中的虚假共享是什么?
【8月更文挑战第21天】
38 0
|
5月前
|
Python
Python代码优化避免全局变量
【7月更文挑战第22天】
63 2
|
5月前
|
Java Linux
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
|
4月前
|
Cloud Native Java 调度
项目环境测试问题之线程同步器会造成执行完任务的worker等待的情况如何解决
项目环境测试问题之线程同步器会造成执行完任务的worker等待的情况如何解决
|
4月前
|
Java 测试技术 PHP
父子任务使用不当线程池死锁怎么解决?
在Java多线程编程中,线程池有助于提升性能与资源利用效率,但若父子任务共用同一池,则可能诱发死锁。本文通过一个具体案例剖析此问题:在一个固定大小为2的线程池中,父任务直接调用`outerTask`,而`outerTask`再次使用同一线程池异步调用`innerTask`。理论上,任务应迅速完成,但实际上却超时未完成。经由`jstack`输出的线程调用栈分析发现,线程陷入等待状态,形成“死锁”。原因是子任务需待父任务完成,而父任务则需等待子任务执行完毕以释放线程,从而相互阻塞。此问题在测试环境中不易显现,常在生产环境下高并发时爆发,重启或扩容仅能暂时缓解。