python多线程如何获取有序结果

 更新时间:2024年09月10日 08:34:36   作者:我是谁,我在哪,我在干啥  
在Python中,多线程编程是一个常见需求,尤其是在处理I/O密集型任务时,然而,多线程环境下保持任务执行结果的顺序通常较为复杂,为了解决这一问题,可以通过封装一个功能来确保即使在多线程环境下,任务的执行结果也能按照一定的顺序进行收集和处理

python多线程获取有序结果

功能封装

import threading

class MyThread(threading.Thread):
    def __init__(self, func, args, name=''):
        threading.Thread.__init__(self)
        self.name = name
        self.func = func
        self.args = args
        
    def run(self):
        self.result = self.func(*self.args)
        
    def get_result(self):
        try:
            return self.result
        except Exception:
            return None

执行

def main():
    threads = []
    nloops = 函数列表
    for i in nloops:
        t = MyThread(函数, (参数,))
        threads.append(t)
    for i in threads :   # start threads 此处并不会执行线程,而是将任务分发到每个线程,同步线程。等同步完成后再开始执行start方法
        i.start()
    results= []
    for i in threads:   # jion()方法等待线程完成
        i.join()
        results.append(i.get_result())  # 获取所有结果列表
    print(threads[1].get_result())  # 获取其中一个结果

python同步应用:多个线程有序执行

可以使用互斥锁完成多个任务,有序的进程工作,这就是线程的同步

from threading import Thread, Lock
import time
mutex1= Lock()  # 创建一个互斥锁
mutex2= Lock()  # 创建一个互斥锁
mutex3= Lock()  # 创建一个互斥锁
 
 
def fun1():
    while 1:
        mutex1.acquire()  # 阻塞
        print("线程1 执行")
        mutex2.release()   # 释放锁2,让线程2继续执行
        time.sleep(0.1)
 
 
def fun2():
    while 1:
        mutex2.acquire()  # 阻塞
        print("线程2 执行")
        mutex3.release()   # 释放锁3,让线程3继续执行
        time.sleep(0.1)
 
 
def fun3():
    while 1:
        mutex3.acquire()  # 阻塞
        print("线程3 执行")
        mutex1.release()   # 释放锁1,让线程1继续执行
        time.sleep(0.1)
 
t1 =Thread(target=fun1)  # 创建一个线程对象
t2 =Thread(target=fun2)  # 创建一个线程对象
t3 =Thread(target=fun3)  # 创建一个线程对象
 
mutex2.acquire()  # 将锁2设置为上锁,线程2不能运行
mutex3.acquire()  # 将锁2设置为上锁,线程2不能运行
 
t1.start()  # 开启线程的执行
t2.start()
t3.start()
 
t1.join()  # 回收线程资源
t2.join()
t3.join()

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • python 实现添加标签&打标签的操作

    python 实现添加标签&打标签的操作

    这篇文章主要介绍了python 实现添加标签&打标签的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-05-05
  • 解决python虚拟环境切换无效的问题

    解决python虚拟环境切换无效的问题

    这篇文章主要介绍了解决python虚拟环境切换无效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • 这三个好用的python函数你不能不知道!

    这三个好用的python函数你不能不知道!

    作为21世纪最流行的语言之一,Python当然有很多有趣的功能值得深入探索和研究.今天通过理论和实际例子来讨论,需要的朋友可以参考下
    2021-06-06
  • 数据挖掘之Apriori算法详解和Python实现代码分享

    数据挖掘之Apriori算法详解和Python实现代码分享

    这篇文章主要介绍了数据挖掘之Apriori算法详解和Python实现代码分享,本文先是对Apriori算法做了详细介绍,然后给出了Python版实现代码,需要的朋友可以参考下
    2014-11-11
  • python文件写入write()的操作

    python文件写入write()的操作

    这篇文章主要介绍了python文件写入write()的操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • python里使用正则的findall函数的实例详解

    python里使用正则的findall函数的实例详解

    这篇文章主要介绍了python里使用正则的findall函数的实例详解的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • python3.6 print同一行覆盖打印方式

    python3.6 print同一行覆盖打印方式

    这篇文章主要介绍了python3.6 print同一行覆盖打印方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-08-08
  • python pyautogui实现图片识别点击失败后重试功能

    python pyautogui实现图片识别点击失败后重试功能

    这篇文章主要介绍了python pyautogui实现图片识别点击失败后重试效果,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • python中的yield使用方法

    python中的yield使用方法

    这篇文章主要介绍了python中的yield使用方法,需要的朋友可以参考下
    2014-02-02
  • Python爬虫新手入门之初学lxml库

    Python爬虫新手入门之初学lxml库

    这篇文章主要给大家介绍了关于Python爬虫新手入门之初学lxml库的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12

最新评论