python测试开发基础---threading

2024-09-06 17:04

本文主要是介绍python测试开发基础---threading,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 核心概念

线程(Thread):线程是轻量级的进程,在同一进程内可以并行执行多个任务。线程共享进程的资源,如内存和文件描述符,但每个线程有自己的执行栈和局部变量。

全局解释器锁(GIL):Python中的GIL限制了同一进程中多个线程的真正并行执行。它确保同一时间只有一个线程可以执行Python字节码,这对计算密集型任务可能会影响性能,但对于I/O密集型任务效果仍然良好。

2. threading模块的主要类和方法

2.1 Thread
  • 功能:用来创建和管理线程。
  • 常用方法
    • __init__(self, group=None, target=None, name=None, args=(), kwargs={}):构造函数,创建线程对象。
    • start(self):启动线程,调用run()方法。
    • run(self):线程执行的代码逻辑,子类需要重写此方法。
    • join(self, timeout=None):等待线程完成。
    • is_alive(self):检查线程是否仍在运行。

基本用法示例

import threadingdef print_numbers():for i in range(5):print(i)# 创建线程对象
thread = threading.Thread(target=print_numbers)# 启动线程
thread.start()# 等待线程完成
thread.join()
2.2 Lock
  • 功能:用于线程间的同步,防止数据竞争。
  • 常用方法
    • acquire(blocking=True, timeout=-1):获取锁,blocking指定是否阻塞,timeout指定最大等待时间。
    • release():释放锁。

使用锁的示例

import threadinglock = threading.Lock()def thread_task():with lock:  # 自动获取和释放锁print("Thread is running")threads = [threading.Thread(target=thread_task) for _ in range(5)]for thread in threads:thread.start()for thread in threads:thread.join()
2.3 RLock
  • 功能:可重入锁,允许同一个线程多次获取锁。
  • 常用方法:与Lock类相同,但支持重入。

使用RLock的示例

import threadingrlock = threading.RLock()def thread_task():with rlock:# 允许多次获取with rlock:print("Thread is running")thread = threading.Thread(target=thread_task)
thread.start()
thread.join()
2.4 Event
  • 功能:用于线程间的简单通信,允许线程等待特定事件发生。
  • 常用方法
    • set():标记事件为“已发生”。
    • clear():标记事件为“未发生”。
    • wait(timeout=None):等待事件发生,阻塞直到事件标记为“已发生”或超时。

使用Event的示例

import threading
import timeevent = threading.Event()def worker():print("Worker is waiting for event")event.wait()  # 等待事件被标记为“已发生”print("Worker has detected event")thread = threading.Thread(target=worker)
thread.start()time.sleep(2)
event.set()  # 触发事件
2.5 Condition
  • 功能:提供线程间的复杂同步机制,允许线程在满足特定条件时继续执行。
  • 常用方法
    • acquire():获取锁。
    • release():释放锁。
    • wait(timeout=None):等待条件满足。
    • notify(n=1):通知一个或多个等待的线程。
    • notify_all():通知所有等待的线程。

使用Condition的示例

import threadingcondition = threading.Condition()def consumer():with condition:print("Consumer is waiting")condition.wait()  # 等待通知print("Consumer received notification")def producer():with condition:print("Producer is notifying")condition.notify()  # 发送通知consumer_thread = threading.Thread(target=consumer)
producer_thread = threading.Thread(target=producer)consumer_thread.start()
producer_thread.start()consumer_thread.join()
producer_thread.join()

3. 线程同步和通信

  • 同步:通过LockRLockCondition等类来避免线程间的数据竞争。
  • 通信:使用EventQueue等类来实现线程间的消息传递。

4. 实际应用

  • I/O密集型任务:例如处理多个网络请求、文件操作等。
  • 计算密集型任务:虽然GIL可能会影响效率,但对于混合任务或需要同时处理I/O的计算任务,threading仍然有用。

5. 注意事项

  • 线程安全:在多线程环境下访问共享资源时,需要小心数据竞争和线程安全问题。
  • 死锁:确保所有锁的获取和释放顺序一致,以避免死锁情况。

这篇关于python测试开发基础---threading的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142601

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]