当前位置: 首页 > news >正文

Python笔记之线程库threading

Python笔记之线程库threading

在这里插入图片描述

参考博文
Python多线程笔记——简单函数版和类实现版

code review!

Python 的 threading 库用于在程序中创建和管理线程。线程允许程序并发执行多个任务。以下是 threading 库的详解和一些简洁示例。

基本概念

  • 线程:在一个进程中,一个线程是执行指令的单独路径。
  • 主线程:每个程序启动时都会有一个默认的主线程。
  • GIL(全局解释器锁):Python 的线程受到 GIL 的限制,不能真正并行地运行 CPU 绑定的任务,但在 I/O 密集型任务中仍然可以提高性能。

重要类和方法

  • Thread 类:用于创建线程。
    • start(): 开始线程活动。
    • join(): 阻塞调用线程,直到被调用的线程终止。
    • run(): 线程活动的方法。
  • Lock 类:用于线程间同步,防止竞争条件。
  • RLock 类:可重入锁,允许在同一线程中多次获得锁。
  • Condition 类:用于线程间通信。
  • Semaphore 类:控制对共享资源的访问。
  • Event 类:用于线程间信号通信。

简单示例

1. 创建并启动线程
import threadingdef print_numbers():for i in range(5):print(i)# 创建线程
thread = threading.Thread(target=print_numbers)# 启动线程
thread.start()# 等待线程完成
thread.join()print("Thread has finished execution.")
2. 使用锁同步线程
import threadingcounter = 0
lock = threading.Lock()def increment_counter():global counterwith lock:for _ in range(10000):counter += 1threads = [threading.Thread(target=increment_counter) for _ in range(2)]for thread in threads:thread.start()for thread in threads:thread.join()print(f"Final counter value: {counter}")
3. 创建自定义线程类
import threadingclass MyThread(threading.Thread):def run(self):for i in range(5):print(f"Thread {self.name}: {i}")# 实例化并启动自定义线程
thread = MyThread()
thread.start()
thread.join()

注意事项

  • 线程安全:在访问共享数据时使用锁确保线程安全。
  • 性能:对于 CPU 密集型任务,考虑使用 multiprocessing 模块。
  • 调试:调试多线程程序可能会比较困难,可以使用日志记录来帮助调试。

这些示例展示了如何使用 threading 库创建和管理线程,以及如何解决常见的同步问题。

http://www.lryc.cn/news/475068.html

相关文章:

  • go 包管理
  • Js内建对象
  • AXI接口的实现逻辑和底层原理,在FPGA中如何实现AXI接口,一篇文章足以搞明白!!!
  • 《GBDT 算法的原理推导》 11-12计算损失函数的负梯度 公式解析
  • mysql设计
  • Android 斗鱼面经
  • 【机器学习】26. 聚类评估方法
  • linux 最多能创建多少个 TCP 连接?
  • 我为何要用wordpress搭建一个自己的独立博客
  • Linux系统每日定时备份mysql数据
  • 书生大模型第一关Linux基础知识
  • 机器学习之fetch_olivetti_faces人脸识别--基于Python实现
  • 【系统设计】深入理解HTTP缓存机制:从Read-Through缓存到HTTP缓存的交互流程
  • FLINK单机版安装部署入门-1
  • 深度学习-学习率调整策略
  • 【学员提问bug】小程序在onUnload里面调接口,用来记录退出的时间, 但是接口调用还没成功, 页面就关闭了。如何让接口在onUnload关闭前调用成功?
  • 【刷题13】链表专题
  • Python Turtle模块详解与使用教程
  • 【PTA】4-2 树的同构【数据结构】
  • Node.js——fs模块-同步与异步
  • Java基于微信小程序的私家车位共享系统(附源码,文档)
  • vscode 创建 vue 项目时,配置文件为什么收缩到一起展示了?
  • PySpark任务提交
  • 【果蔬购物商城管理与推荐系统】Python+Django网页界面+协同过滤推荐算法+管理系统网站
  • 【大模型】海外生成式AI赛道的关键玩家:OpenAI、Anthropic之外还有谁?
  • kubevirt cloud-init配置
  • Oracle 大表添加索引的最佳方式
  • 速度了解云原生后端!!!
  • 云计算Openstack 虚拟机调度策略
  • 在 macOS 上添加 hosts 文件解析的步骤