Python程序中的线程操作-concurrent模块

code1
from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
from threading import currentThread
from multiprocessing import current_process
import time,os
 
def task(i):
    print(f'{currentThread().name} 在运行 任务{i}')
    print(f'{current_process().name} 在运行 任务{i}')
    time.sleep(0.2)
    return i**2
 
if __name__ == '__main__':
    pool = ProcessPoolExecutor(4)
    fu_list = []
    for i in range(20):
        future = pool.submit(task,i)
        # print(future.result())  # 拿不到值会阻塞在这里。
        fu_list.append(future)
 
    pool.shutdown(wait=True)  # 等待池内所有任务执行完毕
    for i in fu_list:
        print(i.result())# 拿不到值会阻塞在这里。
outputs
macname@MacdeMacBook-Pro py % python3 cccccc.py
MainThread 在运行 任务0
ForkProcess-1 在运行 任务0
MainThread 在运行 任务1
ForkProcess-2 在运行 任务1
MainThread 在运行 任务2
ForkProcess-3 在运行 任务2
MainThread 在运行 任务3
ForkProcess-4 在运行 任务3
MainThread 在运行 任务4
ForkProcess-1 在运行 任务4
MainThread 在运行 任务5
ForkProcess-2 在运行 任务5
MainThread 在运行 任务6
ForkProcess-3 在运行 任务6
MainThread 在运行 任务7
ForkProcess-4 在运行 任务7
MainThread 在运行 任务8
MainThread 在运行 任务9
ForkProcess-2 在运行 任务8
ForkProcess-3 在运行 任务9
MainThread 在运行 任务10
ForkProcess-1 在运行 任务10
MainThread 在运行 任务11
ForkProcess-4 在运行 任务11
MainThread 在运行 任务12
ForkProcess-1 在运行 任务12
MainThread 在运行 任务13
ForkProcess-2 在运行 任务13
MainThread 在运行 任务14
ForkProcess-3 在运行 任务14
MainThread 在运行 任务15
ForkProcess-4 在运行 任务15
MainThread 在运行 任务16
ForkProcess-1 在运行 任务16
MainThread 在运行 任务17
MainThread 在运行 任务18
ForkProcess-2 在运行 任务17
ForkProcess-3 在运行 任务18
MainThread 在运行 任务19
ForkProcess-4 在运行 任务19
0
1
4
9
16
25
36
49
64
81
100
121
144
169
196
225
256
289
324
361
macname@MacdeMacBook-Pro py %

 
code2
from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
from threading import currentThread
from multiprocessing import current_process
import time,os
 
def task(i):
    print(f'{currentThread().name} 在运行 任务{i}')
    print(f'{current_process().name} 在运行 任务{i}')
    time.sleep(0.2)
    return i**2
def parse(future):
    # print(future.result())
    print(currentThread().name,'拿到了结果',future.result()) # 如果是线程池 执行完当前任务 负责执行回调函数的是执行任务的线程。
    print(current_process().name,'拿到了结果',future.result()) # 如果是进程池 执行完当前任务 负责执行回调函数的是执行任务的是主进程
 
 
if __name__ == '__main__':
    pool = ProcessPoolExecutor(4)
    #pool = ThreadPoolExecutor(4)
    fu_list = []
    for i in range(20):
        future = pool.submit(task,i)
        future.add_done_callback(parse) # 绑定回调函数
        # 当任务执行结束拿到返回值的时候自动触发回调函数。并且把future当做参数直接传给回调函数parse
outputs
macname@MacdeMacBook-Pro py % python3 cccccc.py
MainThread 在运行 任务0
ForkProcess-1 在运行 任务0
MainThread 在运行 任务1
ForkProcess-2 在运行 任务1
MainThread 在运行 任务2
ForkProcess-3 在运行 任务2
MainThread 在运行 任务3
ForkProcess-4 在运行 任务3
MainThread 在运行 任务4
ForkProcess-3 在运行 任务4
MainThread 在运行 任务5
ForkProcess-1 在运行 任务5
MainThread 在运行 任务6
ForkProcess-4 在运行 任务6
MainThread 在运行 任务7
ForkProcess-2 在运行 任务7
QueueManagerThread 拿到了结果 4
MainProcess 拿到了结果 4
QueueManagerThread 拿到了结果 0
MainProcess 拿到了结果 0
QueueManagerThread 拿到了结果 9
MainProcess 拿到了结果 9
QueueManagerThread 拿到了结果 1
MainProcess 拿到了结果 1
MainThread 在运行 任务8
ForkProcess-2 在运行 任务8
MainThread 在运行 任务9
ForkProcess-3 在运行 任务9
MainThread 在运行 任务10
ForkProcess-4 在运行 任务10
MainThread 在运行 任务11
QueueManagerThread 拿到了结果 49
ForkProcess-1 在运行 任务11
MainProcess 拿到了结果 49
QueueManagerThread 拿到了结果 16
MainProcess 拿到了结果 16
QueueManagerThread 拿到了结果 36
MainProcess 拿到了结果 36
QueueManagerThread 拿到了结果 25
MainProcess 拿到了结果 25
MainThread 在运行 任务12
ForkProcess-4 在运行 任务12
MainThread 在运行 任务13
MainThread 在运行 任务14
ForkProcess-1 在运行 任务13
ForkProcess-3 在运行 任务14
QueueManagerThread 拿到了结果 100
MainThread 在运行 任务15
MainProcess 拿到了结果 100
ForkProcess-2 在运行 任务15
QueueManagerThread 拿到了结果 121
MainProcess 拿到了结果 121
QueueManagerThread 拿到了结果 81
MainProcess 拿到了结果 81
QueueManagerThread 拿到了结果 64
MainProcess 拿到了结果 64
MainThread 在运行 任务16
MainThread 在运行 任务17
ForkProcess-4 在运行 任务16
ForkProcess-1 在运行 任务17
MainThread 在运行 任务18
MainThread 在运行 任务19
ForkProcess-3 在运行 任务18
ForkProcess-2 在运行 任务19
QueueManagerThread 拿到了结果 144
MainProcess 拿到了结果 144
QueueManagerThread 拿到了结果 169
MainProcess 拿到了结果 169
QueueManagerThread 拿到了结果 196
MainProcess 拿到了结果 196
QueueManagerThread 拿到了结果 225
MainProcess 拿到了结果 225
QueueManagerThread 拿到了结果 324
MainProcess 拿到了结果 324
QueueManagerThread 拿到了结果 289
MainProcess 拿到了结果 289
QueueManagerThread 拿到了结果 361
MainProcess 拿到了结果 361
QueueManagerThread 拿到了结果 256
MainProcess 拿到了结果 256
macname@MacdeMacBook-Pro py %
 
 
code3
from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
from threading import currentThread
from multiprocessing import current_process
import time,os
 
def task(i):
    print(f'{currentThread().name} 在运行 任务{i}')
    print(f'{current_process().name} 在运行 任务{i}')
    time.sleep(0.2)
    return i**2
def parse(future):
    # print(future.result())
    print(currentThread().name,'拿到了结果',future.result()) # 如果是线程池 执行完当前任务 负责执行回调函数的是执行任务的线程。
    print(current_process().name,'拿到了结果',future.result()) # 如果是进程池 执行完当前任务 负责执行回调函数的是执行任务的是主进程
 
if __name__ == '__main__':
    #pool = ProcessPoolExecutor(4)
    pool = ThreadPoolExecutor(4)
    fu_list = []
    for i in range(20):
        future = pool.submit(task,i)
        future.add_done_callback(parse) # 绑定回调函数
        # 当任务执行结束拿到返回值的时候自动触发回调函数。并且把future当做参数直接传给回调函数parse
outputs
macname@MacdeMacBook-Pro py % python3 cccccc.py
ThreadPoolExecutor-0_0 在运行 任务0
MainProcess 在运行 任务0
ThreadPoolExecutor-0_1 在运行 任务1
ThreadPoolExecutor-0_2 在运行 任务2
ThreadPoolExecutor-0_3 在运行 任务3
MainProcess 在运行 任务3
MainProcess 在运行 任务1
MainProcess 在运行 任务2
ThreadPoolExecutor-0_0 拿到了结果 0
MainProcess 拿到了结果 0
ThreadPoolExecutor-0_0 在运行 任务4
MainProcess 在运行 任务4
ThreadPoolExecutor-0_2 拿到了结果 4
MainProcess 拿到了结果 4
ThreadPoolExecutor-0_2 在运行 任务5
MainProcess 在运行 任务5
ThreadPoolExecutor-0_3 拿到了结果 9
MainProcess 拿到了结果 9
ThreadPoolExecutor-0_3 在运行 任务6
MainProcess 在运行 任务6
ThreadPoolExecutor-0_1 拿到了结果 1
MainProcess 拿到了结果 1
ThreadPoolExecutor-0_1 在运行 任务7
MainProcess 在运行 任务7
ThreadPoolExecutor-0_0 拿到了结果 16
ThreadPoolExecutor-0_2 拿到了结果 25
ThreadPoolExecutor-0_1 拿到了结果 49
ThreadPoolExecutor-0_3 拿到了结果 36
MainProcess 拿到了结果 36
MainProcess 拿到了结果 16
MainProcess 拿到了结果 49
MainProcess 拿到了结果 25
ThreadPoolExecutor-0_3 在运行 任务8
ThreadPoolExecutor-0_0 在运行 任务9
ThreadPoolExecutor-0_2 在运行 任务11
ThreadPoolExecutor-0_1 在运行 任务10
MainProcess 在运行 任务9
MainProcess 在运行 任务10
MainProcess 在运行 任务8
MainProcess 在运行 任务11
ThreadPoolExecutor-0_0 拿到了结果 81
MainProcess 拿到了结果 81
ThreadPoolExecutor-0_0 在运行 任务12
MainProcess 在运行 任务12
ThreadPoolExecutor-0_1 拿到了结果 100
ThreadPoolExecutor-0_2 拿到了结果 121
MainProcess 拿到了结果 121
ThreadPoolExecutor-0_3 拿到了结果 64
ThreadPoolExecutor-0_2 在运行 任务13
MainProcess 拿到了结果 64
MainProcess 拿到了结果 100
ThreadPoolExecutor-0_3 在运行 任务14
MainProcess 在运行 任务13
MainProcess 在运行 任务14
ThreadPoolExecutor-0_1 在运行 任务15
MainProcess 在运行 任务15
ThreadPoolExecutor-0_2 拿到了结果 169
MainProcess 拿到了结果 169
ThreadPoolExecutor-0_2 在运行 任务16
MainProcess 在运行 任务16
ThreadPoolExecutor-0_1 拿到了结果 225
MainProcess 拿到了结果 225
ThreadPoolExecutor-0_0 拿到了结果 144
ThreadPoolExecutor-0_3 拿到了结果 196
MainProcess 拿到了结果 144
ThreadPoolExecutor-0_1 在运行 任务17
MainProcess 拿到了结果 196
MainProcess 在运行 任务17
ThreadPoolExecutor-0_3 在运行 任务19
ThreadPoolExecutor-0_0 在运行 任务18
MainProcess 在运行 任务19
MainProcess 在运行 任务18
ThreadPoolExecutor-0_2 拿到了结果 256
MainProcess 拿到了结果 256
ThreadPoolExecutor-0_3 拿到了结果 361
MainProcess 拿到了结果 361
ThreadPoolExecutor-0_0 拿到了结果 324
ThreadPoolExecutor-0_1 拿到了结果 289
MainProcess 拿到了结果 324
MainProcess 拿到了结果 289
macname@MacdeMacBook-Pro py %

 

 
 
 
 
 
 
 
 
 
 

posted @ 2020-12-26 18:57  anobscureretreat  阅读(141)  评论(0编辑  收藏  举报