python:多线程 简单示例

在Python中,多线程编程通常用于执行I/O密集型任务,因为Python的全局解释器锁(GIL)限制了多线程在CPU密集型任务上的性能提升。不过,对于需要同时处理多个I/O操作(如网络请求、文件读写等)的场景,多线程仍然非常有用。

Python的 threading 模块提供了创建和管理线程的基本工具。以下是一个简单的示例,展示了如何使用threading模块来创建和启动多个线程:

python 复制代码
import threading
import time
 
# 线程执行的函数
def worker(thread_id, delay):
    print(f"线程 {thread_id} 开始工作,延迟 {delay} 秒")
    time.sleep(delay)
    print(f"线程 {thread_id} 完成工作")
 
# 创建线程列表
threads = []
 
# 启动多个线程
for i in range(5):
    thread = threading.Thread(target=worker, args=(i, 2))  # 创建一个线程对象
    threads.append(thread)
    thread.start()  # 启动线程
 
# 等待所有线程完成
for thread in threads:
    thread.join()
 
print("所有线程已完成")

在这个示例中,我们定义了一个简单的worker函数,该函数接受线程ID和延迟时间作为参数,模拟线程的工作。然后,我们创建了5个线程,每个线程都会调用worker函数,并传入不同的参数。最后,我们使用join()方法等待所有线程完成。

线程同步

多线程编程中,线程同步是一个重要问题。如果不加以控制,多个线程可能会同时访问共享资源,导致数据竞争和不一致。Python的threading模块提供了多种同步机制,如锁(Lock)、信号量(Semaphore)、条件变量(Condition)等。

以下是一个使用锁的示例:

python 复制代码
import threading
 
# 共享资源
counter = 0
lock = threading.Lock()
 
# 线程执行的函数
def increment():
    global counter
    for _ in range(100000):
        lock.acquire()  # 获取锁
        counter += 1
        lock.release()  # 释放锁
 
# 创建线程列表
threads = []
 
# 启动多个线程
for _ in range(10):
    thread = threading.Thread(target=increment)
    threads.append(thread)
    thread.start()
 
# 等待所有线程完成
for thread in threads:
    thread.join()
 
print(f"最终计数器值: {counter}")

在这个示例中,我们使用了一个锁来保护对共享资源counter的访问。每个线程在修改counter之前都会先获取锁,修改完成后释放锁。这样可以确保同一时间只有一个线程能够访问counter,从而避免了数据竞争。

注意事项

全局解释器锁(GIL):Python的GIL限制了多线程在CPU密集型任务上的性能提升。对于这类任务,可以考虑使用multiprocessing模块来创建多个进程,每个进程都有自己的Python解释器和内存空间,从而绕过GIL的限制。

线程安全:确保线程访问共享资源时是线程安全的,可以使用锁、信号量等同步机制。

死锁:不当使用锁可能会导致死锁问题,即多个线程相互等待对方释放锁,从而永远无法继续执行。要避免死锁,需要确保每个线程都能按照相同的顺序获取锁。

性能开销:创建和销毁线程是有开销的,不要频繁创建和销毁线程。可以使用线程池(如concurrent.futures.ThreadPoolExecutor)来重用线程。

通过合理使用多线程编程,可以显著提高程序的并发性能和响应速度。然而,也需要注意多线程编程带来的复杂性和潜在问题。

相关推荐
Hgfdsaqwr1 天前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
weixin_395448911 天前
export_onnx.py_0130
pytorch·python·深度学习
s1hiyu1 天前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python
2301_763472461 天前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
无垠的广袤1 天前
【VisionFive 2 Lite 单板计算机】边缘AI视觉应用部署:缺陷检测
linux·人工智能·python·opencv·开发板
Duang007_1 天前
【LeetCodeHot100 超详细Agent启发版本】字母异位词分组 (Group Anagrams)
开发语言·javascript·人工智能·python
浒畔居1 天前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
抠头专注python环境配置1 天前
基于Pytorch ResNet50 的珍稀野生动物识别系统(Python源码 + PyQt5 + 数据集)
pytorch·python
百***78751 天前
Kimi K2.5开源模型实战指南:核心能力拆解+一步API接入(Python版,避坑全覆盖)
python·microsoft·开源
喵手1 天前
Python爬虫实战:针对天文历法网站(以 TimeandDate 或类似的静态历法页为例),构建高精度二十四节气天文数据采集器(附xlsx导出)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集天文历法网站数据·构建二十四节气天文数据