【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方法,Thread还有一个参数是args用来给函数传入参数
    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!")        
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

SamRol

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值