python threading异步并发调用示例

在开发python服务中,经常会遇到不再等待实际任务运行,需要提前返回。

比如,图像生成、LLM调用,这类任务运行时间较长。

一般主程序在异步启动实际任务后,会提前退出,然后隔一段时间轮询一次,检查任务是否完成。

python有多种方式实现异步执行,这里通过threading方式实现异步执行。

首先示例正常运行程序,然后尝试改为threading异步版本。

所用示例代码参考和修改自网络资料。

1 同步调用

1.1 同步运行分析

这是一个正常运行的程序,在main中以顺序执行的方式,分别运行阻塞程序1、阻塞程序2。

由于不涉及异步执行,所以没有实际用到threading包。

同步运行控制简单,存在的问题是一个时间段只能运行一个程序,效率较低。

1.2 同步运行示例

这是同步运行程序的示例代码

复制代码
import  threading,time

def thead(num):
    time.sleep(1)
    print("阻塞程序%s开始执行"%num)
    time.sleep(3)
    print("阻塞程序%s执行完毕"%num)

def main():
    print("主方法开始执行")

    for i in range(1, 3):
        thead(i)

    print("主方法执行完毕")
    return

if __name__ == '__main__':
    print(time.ctime())
    num = main()
    print("返回结果为%s"%num)
    print(time.ctime())

如下所示,首先程序1运行开始,程序1结束,然后程序2开始,程序2结束,整个过程顺序进行。

Thu Dec 4 09:50:42 2025

主方法开始执行

阻塞程序1开始执行

阻塞程序1执行完毕

阻塞程序2开始执行

阻塞程序2执行完毕

主方法执行完毕

返回结果为None

Thu Dec 4 09:50:50 2025

2 异步调用

2.1 异步运行分析

由于一些实际需求,主方法main可能需要在启动程序1和程序2后提前退出。

这个时候就会用到python threading的异步执行功能。

主方法main通过threading分别为程序1和程序2创建线程1和线程2,示例代码如下。

poll = []#线程池

for i in range(1,3):

thead_one = threading.Thread(target=thead, args=(i,))

poll.append(thead_one) #线程池添加线程

然后,主方法main在分别异步启动线程1和线程2,示例代码如下。

for n in poll:

n.start() #准备就绪,等待cpu执行

启动完成后,主方法main就可以提前退出了。

print("主方法执行完毕")

return

主方法main退出后,线程1和线程2可能还在异步运行。

异步运行控制复杂,然而可减少主程序等待,在同一时间段并发运行多个程序,效率高。

2.2 异步运行示例

这是异步运行程序的示例代码。

复制代码
import  threading,time

def thead(num):
    # time.sleep(1)
    print("线程%s开始执行"%num)
    time.sleep(3)
    print("线程%s执行完毕"%num)

def main():
    print("主方法开始执行")

    #创建2个线程
    poll = []#线程池
    for i in range(1,3):
        thead_one = threading.Thread(target=thead, args=(i,))
        poll.append(thead_one) #线程池添加线程
    for n in poll:
        n.start()   #准备就绪,等待cpu执行
        
    print("主方法执行完毕")
    return

if __name__ == '__main__':
    print(time.ctime())
    num = main()
    print("返回结果为%s"%num)
    print(time.ctime())

输出如下所示,

主方法在启动线程1、线程2后就退出

线程1、线程2转为后台并发运行,其退出时间可以晚于主方法的退出时间。

然而,线程1、线程2同时并行运行,能减少等待时间,提高运行效率。

Thu Dec 4 10:02:29 2025

主方法开始执行

线程1开始执行

线程2开始执行

主方法执行完毕

返回结果为None

Thu Dec 4 10:02:29 2025

线程1执行完毕

线程2执行完毕

reference


python线程实现异步任务

https://www.cnblogs.com/lyxdw/p/9993293.html

python使用async和await并发编程示例

https://blog.csdn.net/liliang199/article/details/151117291

相关推荐
宝贝儿好21 小时前
【LLM】第一章:分词算法BPE、WordPiece、Unigram、分词工具jieba
人工智能·python·深度学习·神经网络·算法·语言模型·自然语言处理
清水白石00821 小时前
Python 在数据栈中的边界:何时高效原型、何时切换到 SQL、Spark、Rust 或数据库原生能力
数据库·python·自动化
青瓷程序设计21 小时前
基于深度学习的【猫类识别系统】~Python+深度学习+人工智能+算法模型+2026原创+计算机毕设
人工智能·python·深度学习
好家伙VCC21 小时前
**InfluxDB实战进阶:基于Golang的高性能时序数据采集与可视化方
java·开发语言·后端·python·golang
好家伙VCC21 小时前
**发散创新:基于Go语言的服务网格实践与流量治理实战**在微服务架构日益复杂的今天,**服务网格(S
java·python·微服务·架构·golang
疯狂成瘾者21 小时前
抽象类 vs 具体实现类的关系
python·langchain
心静财富之门1 天前
Flask 详细讲解 + 实战实例(零基础可学)
后端·python·flask
架构师老Y1 天前
003、Python Web框架深度对比:Django vs Flask vs FastAPI
前端·python·django
疯狂成瘾者1 天前
语义分块提升RAG检索精度
python
小陈工1 天前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python