python多线程和线程池实现

1. 多线程处理

先计算 num - 1,返回
再计算 add(num)

from concurrent.futures import ThreadPoolExecutor
import time
import logging
import traceback

"""
多线程处理
"""
def add(num):
    return num+1

class CreditService():
    def __init__(self, thread_pool_num):
        self.thread_pool = ThreadPoolExecutor(thread_pool_num)
        self.thread_pool_num = thread_pool_num
        self.task_handler_list = []
       
    def extract_credit_service(self, name, num):
        task_handler = self.thread_pool.submit(lambda p: self.main_credit_service(*p), [name, num])
        self.task_handler_list.append(task_handler)
        while True:
            for task_handler_tmp in self.task_handler_list:
                if task_handler_tmp.done():
                    self.task_handler_list.remove(task_handler_tmp)
            if len(self.task_handler_list) > 2 * self.thread_pool_num:
                time.sleep(10)
            else:
                return True

    def main_credit_service(self, name, num):
        try:
            num_add = add(num)
            time.sleep(5)
            print(name, num_add)
        except Exception as e:
            traceback.print_exc()
            traceback.print_exc(file=open('log.txt', 'a'))


thread_pool_num = 2
credit_service = CreditService(thread_pool_num) # 只初始化一次

def mianmian(st, i):
    credit_service.extract_credit_service(st, i)
    return i-1
    
if __name__ == "__main__": 
    print(mianmian("aa",3))
    print(mianmian("bb",4))
    print(mianmian("cc",5))

输出:

2
3
4
aa 4
bb 5
cc 6

2. 多线程处理,add函数为异步

import asyncio

async def add(num): # 异步函数
    return num+1
    
# 将异步函数转为同步函数
def sync_add(num):
    # 使用 asyncio.run 来运行异步的 add
    return asyncio.run(add(num))

整体:

from concurrent.futures import ThreadPoolExecutor
import time
import logging
import traceback
import asyncio

"""
多线程处理
"""
async def add(num): # 异步函数
    return num+1

class CreditService():
    def __init__(self, thread_pool_num):
        self.thread_pool = ThreadPoolExecutor(thread_pool_num)
        self.thread_pool_num = thread_pool_num
        self.task_handler_list = []
       
    def extract_credit_service(self, name, num):
        task_handler = self.thread_pool.submit(lambda p: self.main_credit_service(*p), [name, num])
        self.task_handler_list.append(task_handler)
        while True:
            for task_handler_tmp in self.task_handler_list:
                if task_handler_tmp.done():
                    self.task_handler_list.remove(task_handler_tmp)
            if len(self.task_handler_list) > 2 * self.thread_pool_num:
                time.sleep(10)
            else:
                return True

    def main_credit_service(self, name, num):
        try:
            num_add = asyncio.run(add(num))
            time.sleep(5)
            print(name, num_add)
        except Exception as e:
            traceback.print_exc()
            traceback.print_exc(file=open('log.txt', 'a'))


thread_pool_num = 2
credit_service = CreditService(thread_pool_num) # 只初始化一次

def mianmian(st, i):
    credit_service.extract_credit_service(st, i)
    return i-1
    
if __name__ == "__main__": 
    print(mianmian("aa",3))
    print(mianmian("bb",4))
    print(mianmian("cc",5))

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/924672.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Git 进程占用报错-解决方案

背景 大仓库,由于开发者分支较多,我们在使用 git pull 或 git push 等命令时(与远端仓库交互的命令),不知之前配置了什么,我的电脑会必现以下报错(有非常长一大串报错-不同分支的git进程占用报…

STM32完全学习——使用标准库完成PWM输出

一、TIM2初始化 我这里使用的是STM32F407ZGT6这个芯片,我这里使用的是定时器TIM2来完成PWM输出,由于这里没有使用中断,因此不需要初始化NVIC,下面先来进行定时器的相关初始化 TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;R…

【爬虫框架:feapder,管理系统 feaplat】

github:https://github.com/Boris-code/feapder 爬虫管理系统 feaplat:http://feapder.com/#/feapder_platform/feaplat 爬虫在线工具库 :http://www.spidertools.cn :https://www.kgtools.cn/1、feapder 简介 对于学习 Python…

路由引入中次优路由和路由环路问题

A公司用的是IS-IS,B公司用的是OSPF,现在这两个公司要合并,网络要相通 项目目标 前期准备 配置IP地址:完成IP地址规划,A公司和B公司内部网络通过路由器R2和R4环回接口模拟。配置路由器接口的IP地址并测试所有直连链路的…

使用Compose Multiplatform开发跨平台的Android调试工具

背景 最近对CMP跨平台很感兴趣,为了练手,在移动端做了一个Android和IOS共享UI和逻辑代码的天气软件,简单适配了一下双端的深浅主题切换,网络状态监测,刷新调用振动器接口。 做了两年多车机Android开发,偶…

通过LabVIEW项目判断开发环境是否正版

在接收或分析他人提供的LabVIEW项目时,判断其开发环境是否为正版软件对于保护知识产权和避免使用非法软件至关重要。本文将详细介绍如何通过项目文件、可执行程序及开发环境信息判断LabVIEW是否为正版。 ​ 1. 从项目文件判断 LabVIEW项目的源码(VI 文件…

React的ts文件中通过createElement拼接一段内容出来

比如接口返回一个值 const values [23.00, 40.00/kg];想做到如下效果, 如果单纯的用render渲染会很简单, 但是在ts文件中处理,所以采用了createElement拼接 代码如下: format: (values: string[]) > {if (!values || !val…

计算机网络 实验七 NAT配置实验

一、实验目的 通过本实验理解网络地址转换的原理和技术,掌握扩展NAT/NAPT设计、配置和测试。 二、实验原理 NAT配置实验的原理主要基于网络地址转换(NAT)技术,该技术用于将内部私有网络地址转换为外部公有网络地址,从…

002 MATLAB语言基础

01 变量命名规则 变量名只能由字母、数字和下划线组成,且必须以字母开头; 变量名区分字母的大小写; 变量名不能超过最大长度限制; 关键字不能作为变量名,如for、end和if等; 注意:存变量命名时…

无线WiFi网络版毫米波雷达人体传感器,智能家居节能减排照明有人无人识别

在这个科技日新月异的时代,智能家居已经不再是遥不可及的未来概念,而是悄然融入了我们的日常生活,为我们的生活带来了未有的便捷与舒适。今天,让我们一起探索一项创新性的智能家居技术——飞睿智能无线WiFi网络版毫米波雷达人体传…

AI前景分析展望——GPTo1 SoraAI

引言 人工智能(AI)领域的飞速发展已不仅仅局限于学术研究,它已渗透到各个行业,影响着从生产制造到创意产业的方方面面。在这场技术革新的浪潮中,一些领先的AI模型,像Sora和OpenAI的O1,凭借其强大…

Qwen2.5-7B大模型微调记录

Qwen2.5-7B大模型微调记录 研究需要,需要搞一个大模型出来,没有太多的时间自己训练,准备用现成的开源大模型,然后结合研究方向进行微调 前前后后折腾大半个月,总算做完了第一个微调的大模型,模型基于阿里…

Spring Aop 中对JoinPoint的理解

以下是源码中对 JoinPoint 的描述 A runtime joinpoint is an event that occurs on a static joinpoint (i.e. a location in a program). For instance, an invocation is the runtime joinpoint on a method (static joinpoint). The static part of a given joinpoint can…

netstat -tuln | grep 27017(显示所有监听状态的 TCP 和 UDP 端口,并且以数字形式显示地址和端口号)

文章目录 1. 确定占用端口的进程使用 lsof 命令使用 fuser 命令 2. 结束占用端口的进程3. 修改 MongoDB 配置文件4. 检查 MongoDB 日志文件5. 重新启动 MongoDB 服务6. 检查 MongoDB 服务状态总结 [rootlocalhost etc]# netstat -tuln | grep 27017 tcp 0 0 127.0.…

java脚手架系列16-AI大模型集成

之所以想写这一系列,是因为之前工作过程中有几次项目是从零开始搭建的,而且项目涉及的内容还不少。在这过程中,遇到了很多棘手的非业务问题,在不断实践过程中慢慢积累出一些基本的实践经验,认为这些与业务无关的基本的…

若依框架部署在网站一个子目录下(/admin)问题(

部署在子目录下首先修改vue.config.js文件: 问题一:登陆之后跳转到了404页面问题,解决办法如下: src/router/index.js 把404页面直接变成了首页(大佬有啥优雅的解决办法求告知) 问题二:退出登录…

NAT:连接私有与公共网络的关键技术(4/10)

一、NAT 的工作原理 NAT 技术的核心功能是将私有 IP 地址转换为公有 IP 地址,使得内部网络中的设备能够与外部互联网通信。其工作原理主要包括私有 IP 地址到公有 IP 地址的转换、端口号映射以及会话表维护这几个步骤。 私有 IP 地址到公有 IP 地址的转换&#xff1…

在 Ubuntu 上部署 MediaWiki 开源维基平台

MediaWiki 是一个功能强大的开源维基软件,全球众多组织使用它来创建协作文档网站。本文将指导你如何在 Ubuntu 服务器上安装 MediaWiki,使用 Nginx 作为 Web 服务器,PostgreSQL 作为数据库管理系统。 简介 MediaWiki 是一个灵活且强大的维基…

彻底理解如何保证ElasticSearch和数据库数据一致性问题

一.业务场景举例 需求: 一个卖房业务,双十一前一天,维护楼盘的运营人员突然接到合作开发商的通知,需要上线一批热门的楼盘列表,上传完成后,C端小程序支持按楼盘的名称、户型、面积等产品属性全模糊搜索热门…

ReactPress(阮一峰推荐工具):一款基于Next.js的免费开源博客CMS系统

ReactPress Github项目地址:https://github.com/fecommunity/reactpress 欢迎Star。 此项目是用于构建博客网站的,包含前台展示、管理后台和后端。 此项目是基于 React antd NestJS NextJS MySQL 的,项目已经开源,项目地址在 …