python_100个数多线程打印

问题:1-100个数多线程打印

import threadpool

def pool_num(num,p_methond,num_list):
    pool=threadpool.ThreadPool(num) #声明线程池个数
    reqs=threadpool.makeRequests(p_methond,num_list) #生成线程池启动参数
    [pool.putRequest(req) for req in reqs] #循环执行启动线程
    pool.wait() #等待子线程
def p_methond(num):
    print(num)
num_list=[i for i in range(1,101)]
pool_num(3,p_methond,num_list)

 问题:1-100个数,线程数可以自定义,然后多线程打印这1-100个数,要求每个线程打印的数分段连续打印,比如说用2个线程,那么线程1是打印1-50,线程2是打印51-100

线程方式实现

import threading

def func(arg): #打印数字函数
    for i in arg:
        print("当前线程:", threading.currentThread().name, "----", i+1)

def thread_num(total,num): #传参是打印数字的总数及线程数
    data = [x for x in range(0, total)] #所有的数字循环放入list
    split_data = [data[i: i + int(total/num)] for i in range(0, len(data), int(total/num))] #带步长的循环list,且每段放入一个list,生成2维数组

    for d in split_data: #循环二维数组,每次取一个数组,作为打印函数的传参
        t = threading.Thread(target=func, args=(d,))  #生成线程且调用方法及给予传参
        t = t.start()#启动线程

    while threading.active_count()!=1: #等待子线程
        pass


thread_num(13,2) #调用线程方法

numpy模块分段:

import threading
import numpy

def func(arg):
    for i in arg:
        print(threading.currentThread().name, "----", i+1)

def thread_num(total,num):
    result=numpy.array_split(range(total),num) #分段
    for  i in result:
        t=threading.Thread(target=func,args=(i,)) #声明线程
        t.start() #启动线程

    while threading.active_count()!=1: #等待子线程
        pass

随记:问题--为什么等子线程

开了几个线程执行任务,如果不等待线程, 如果你的进程挂了的时候,线程也会挂掉

还有一个场景, 如果你要等待所有线程处理完后的结果,那就必须等待了

 

posted @ 2019-09-06 14:46  小戳同学  阅读(2896)  评论(0编辑  收藏  举报