Python多进程

1.linux多进程

import os
import time
pid = os.fork()

if pid == 0:
    print('子进程:{}父进程{}'.format(os.getpgid(),os.getppid()))
else:
    print('我是父进程{}'.format(pid))
time.sleep(2)
View Code

2.跨平台多进程multiprocessing

import time
from concurrent.futures import ProcessPoolExecutor
import multiprocessing
def get_html(n):
    time.sleep(n)
    print(n)
    print(33)
    return n
if __name__=='__main__':
 
    pro = multiprocessing.Process(target=get_html, args=(2,))
    pro.start()
    pro.join()
View Code

3.使用进程池

import time
from concurrent.futures import ProcessPoolExecutor
import multiprocessing
def get_html(n):
    print('逆火')
    time.sleep(n)
    print(n)

    return n
if __name__=='__main__':
    print("合数{}".format(multiprocessing.cpu_count()))
    Pool = multiprocessing.Pool(multiprocessing.cpu_count())
    # result = Pool.apply_async(get_html, args=(3,))
    # #等待所有任务完成
    # Pool.close()
    # Pool.join()
    # print(result.get())

    for ret in Pool.imap(get_html, [1,5,3]):
        print('返回值{}'.format(ret))
View Code

4.进程间的通信

  使用queue

from multiprocessing import Manager,Queue,Process
import time
def shengchan(que):
    n = 0
    while True:
        time.sleep(1)

        n+=1
        print('生产者{}'.format(n))
        que.put(n)
def xiaofeizhe(que):
    while True:
        time.sleep(1)
        print('消费者{}'.format(que.get()))




if __name__=='__main__':
    queue = Queue(10)
    pro = Process(target=shengchan, args=(queue,))
    pro1 = Process(target=xiaofeizhe , args=(queue,))
    pro.start()
    pro1.start()
    pro.join()
    pro1.join()
View Code

 

  使用Manager

  使用进程池的话 无法用queue进行通信  就要使用到Manager.queue进行通信

import time
from concurrent.futures import ProcessPoolExecutor
from multiprocessing import Manager,Pool,cpu_count
def shengchan(que):
    n = 0
    while True:

        n+=1
        print('生产者{}'.format(n))
        que.put(n)
        time.sleep(1)
def xiaofeizhe(que):
     while True:
        print('消费者{}'.format(que.get()))
    
        time.sleep(1)
if __name__=='__main__':
    que = Manager().Queue(10)
    pool = Pool(cpu_count())
    result = pool.apply_async(shengchan, args=(que,))
    result1 = pool.apply_async(xiaofeizhe, args=(que,))
    #等待所有任务完成
    pool.close()
    pool.join()
View Code

  使用pipe

import time
from concurrent.futures import ProcessPoolExecutor
from multiprocessing import Manager,Pool,cpu_count,Pipe
def shengchan(pipe):
    n = 0
    while True:

        n+=1
        print('生产者{}'.format(n))
        pipe.send(n)
        time.sleep(1)
def xiaofeizhe(pipe):
     while True:
        print('消费者{}'.format(pipe.recv()))

        time.sleep(1)
if __name__=='__main__':
    recevie_pipe, send_pipe = Pipe()
    pool = Pool(cpu_count())
    result = pool.apply_async(shengchan, args=(send_pipe,))
    result1 = pool.apply_async(xiaofeizhe, args=(recevie_pipe,))
    #等待所有任务完成
    pool.close()
    pool.join()
View Code

 

转载于:https://www.cnblogs.com/gaosie/p/10816690.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值