栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

【Python】多线程、多进程、线程池

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【Python】多线程、多进程、线程池

一、多线程
  1. 使用多线程需要导入threading模块里的Thread类。
  2. 创建多线程对象,赋予其需要执行的目标。
  3. 启动线程。
#导入类
from threading import  Thread

def func():
    for i in range(500):
        print("子线程:", i)

if __name__ == '__main__':
    t = Thread(target=func)#创建线程类,目标为func方法
    t.start()#开始线程
    for i in range(500):
        print("主线程:", i)

第二种写法:

from threading import  Thread

class MyThread(Thread): #继承Thread类
    def run(self):  #线程启动后执行的是run()里面的内容
        for i in range(100):
            print("子线程:", i)

if __name__ == '__main__':
    t = MyThread()
    t.start()
    for i in range(100):
        print("主线程:", i)

 如果要给函数传参可以这样写:

t = Thread(target=func, args=("传参",))#args里面必须是元组

二、多进程
  1. 使用多进程需要导入multiprocessing模块里的Process类。
  2. 创建多进程对象,赋予其需要执行的目标。
  3. 启动线程。
from multiprocessing import  Process
def func():
    for i in range(100):
        print("子进程:",i)

if __name__ == '__main__':
    p = Process(target=func)
    p.start()
    for i in range(100):
        print("主进程:",i)

三、线程池

线程池:一次性开辟一些线程。用户直接把提交抛给线程池,线程任务的调度交给线程池来完成。

  1. 使用多进程需要导入concurrent.futures里的ThreadPoolExecutor和ProcessPoolExecutor类。
  2. 创建线程池,并设置线程数。
  3. 提交任务。
from concurrent.futures import  ThreadPoolExecutor,ProcessPoolExecutor
def func(name):
    for i in range(500):
        print(name,i)

if __name__ == '__main__':
    #创建线程池,添加50个线程
   with ThreadPoolExecutor(50) as t:
       for i in range(100):
           t.submit(func, name = "子线程") #提交任务,设置参数
   #等待线程池中的任务全部执行完毕,才继续执行线程池外的内容
   print("done!")        
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/587809.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号