登录
首页 >  文章 >  python教程

Python多线程调用多个函数技巧

时间:2026-05-08 15:07:55 346浏览 收藏

本文深入浅出地讲解了如何使用Python的threading模块通过多线程并发执行多个函数,涵盖线程创建(target参数)、启动(start)、同步等待(join)、灵活传参(args/kwargs)、批量管理(列表统一控制)等核心技巧,并特别强调了实际开发中极易被忽视的关键点:I/O密集型任务能显著受益于多线程,而CPU密集型任务则受限于GIL难以提速;同时,共享数据必须配合Lock实现线程安全,否则极易引发不可预测的数据竞争问题——掌握这些要点,你就能写出既高效又健壮的并发代码。

python如何使用多线程执行多个函数?

Python 中可以用 threading.Thread 为每个函数创建一个线程,让它们并发执行。注意:由于全局解释器锁(GIL),多线程对 CPU 密集型任务提速有限,但对 I/O 密集型(如网络请求、文件读写)很有效。

基本用法:为每个函数启动一个线程

把目标函数传给 Threadtarget 参数,用 .start() 启动,用 .join() 等待完成:

import threading
import time
<p>def func_a():
print("A 开始")
time.sleep(2)
print("A 结束")</p><p>def func_b():
print("B 开始")
time.sleep(1)
print("B 结束")</p><h1>创建线程</h1><p>t1 = threading.Thread(target=func_a)
t2 = threading.Thread(target=func_b)</p><h1>启动线程</h1><p>t1.start()
t2.start()</p><h1>等待两个线程都结束</h1><p>t1.join()
t2.join()</p><p>print("全部完成")
</p>

传递参数给多线程函数

args(元组)或 kwargs(字典)传参:

def greet(name, times=1):
    for i in range(times):
        print(f"Hello, {name} ({i+1})")
        time.sleep(0.5)
<p>t = threading.Thread(target=greet, args=("Alice",), kwargs={"times": 2})
t.start()
t.join()
</p>

管理多个线程:用列表统一启停

适合同时运行 3 个以上函数,避免重复写 t1t2

  • 把所有 Thread 对象存进列表
  • 遍历调用 .start() 启动全部
  • 再遍历调用 .join() 等待全部结束
threads = []
for func in [func_a, func_b, greet]:
    if func == greet:
        t = threading.Thread(target=func, args=("Bob",))
    else:
        t = threading.Thread(target=func)
    threads.append(t)
<p>for t in threads:
t.start()
for t in threads:
t.join()
</p>

注意线程安全:共享变量要加锁

多个线程修改同一个变量(如计数器、列表)时,可能出错。用 threading.Lock 保护临界区:

counter = 0
lock = threading.Lock()
<p>def increment():
global counter
for _ in range(100000):
with lock:  # 自动 acquire/release
counter += 1</p><p>t1 = threading.Thread(target=increment)
t2 = threading.Thread(target=increment)
t1.start(); t2.start()
t1.join(); t2.join()
print(counter)  # 稳定输出 200000
</p>

基本上就这些。不复杂但容易忽略 join 和锁 —— 忘了 join 主线程会提前退出;忘了锁,数据就可能乱。

文中关于函数,多线程的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Python多线程调用多个函数技巧》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>