PYTHON进程一步步详解

2018-10-15  本文已影响0人  ScienBeast

进程基本概念

进程由程序,数据和进程控制块组成,是正在执行的程序,程序的一次执行过程,是资源调度的基本单位。

进程调度算法:先来先服务调度算法(FCFS),短作业(进程)优先调度算法,时间片轮转等

并行和并发:

并行:微观上,一个精确时间片刻,有不同的程序在执行,要求必须有多个处理器

并发:宏观上,在一个时间段上看是同时执行的,实际是进程的快速切换。

进程三种状态:

image

就绪:已获得运行所需资源,除了cpu资源。

阻塞:等待cpu以外的其他资源

执行→阻塞:执行的进程发生等待事件而无法执行变为阻塞状态。例如IO请求,申请资源得不到满足。

阻塞→就绪:处于阻塞状态在其等待的事件已经发生,并不马上转入执行状态,先转入就绪状态

执行→就绪:时间片用完而被暂停执行。

临界区:一次只允许一个进程进入访问的一段代码。临界区保护原则是有空让进,有限等待。

多进程编程

- 一个子进程处理任务
from multiprocessing import Process

def fun1(s):

        while 1:

                s=s+1
s=0
p=Process(target=fun1,args=(s,))  #创建进程对象

p.start()  #开启进程

p.join()  #主线程等待子线程p终止

cpu检测结果如下:

图中1 和 2 代表了计算机的核数,由于子线程p进程死循环,可以看到第二个核一直处于100%状态 image.png
-两个子进程处理任务
from multiprocessing import Process

def fun1(s):
    while 1:
                s=0
                s=s+1

s=0
p1=Process(target=fun1,args=(s,))
p2=Process(target=fun1,args=(s,))

p1.start()
p2.start()
p1.join()
p2.join()

多进程情况下,双核cpu都处于100%状态 image.png

多进程锁机制

存钱和取钱的例子

from  multiprocessing import Process,Lock

def get_money(num,l):
        l.acquire()              #加锁
        for i in range(100):
                num=num-1
        print (num)
        l.release()             #解锁

def put_money(num,l):
        for i in range(100):
                num=num+1
        print (num)
if __name__=='__main__':
        num=100
        l=Lock()
        p=Process(target=get_money,args=(num,l))
        p.start()
        p1=Process(target=put_money,args=(num,l))
        p1.start()
        p.join()
        p1.join()
#
0
200

由于进程间不能共享资源,结果会出现0 和 200,以后会讲到进程间共享内存时再把代码完善一下。

多进程信号量

from  multiprocessing import Semaphore
if __name__=='__main__':
        l=Semaphore(2)
        l.acquire()
        print (1)
        l.acquire()
        print (2)
        l.acquire()
        print (3)
from  multiprocessing import Semaphore,Process
import time

def fun(i,l):
    l.acquire()
        print(' %s process start work'%i)
        time.sleep(1)
        print ('%s process end'%i)
        l.release()
if __name__=='__main__':
        l=Semaphore(5)
        p_l=[]
    for i in range(10):
                p=Process(target=fun,args=(i,l,))
                p.start()
                p_l.append(p)
        for j in p_l:
                j.join()
#结果输出
0 process start work
 1 process start work
 2 process start work
 3 process start work
 5 process start work
0 process end
1 process end
 7 process start work
2 process end
 6 process start work
 8 process start work
3 process end
 9 process start work
5 process end
 4 process start work
7 process end
6 process end
8 process end
4 process end
9 process end

IPC 进程间通信

from  multiprocessing import Process,Queue
import time
def add(q):
    for i in range(5):
                q.put(i)
                print ("add %s"%i)
                time.sleep(1)
def dele(q):
    for i in range(5):
                result=q.get()
                print ("delete %s"%result)
                time.sleep(1)


if __name__=='__main__':
        q=Queue()
        p=Process(target=add,args=(q,))
        p1=Process(target=dele,args=(q,))
        p.start()
        p1.start()
        p.join()
        p1.join()
#结果
add 0
delete 0
add 1
delete 1
add 2
delete 2
add 3
delete 3
add 4
delete 4

多进程间共享内存数据

from  multiprocessing import Process,Lock,Manager

def get_money(num,l):

        for i in range(100):
                l.acquire()
                num[0]=num[0]-1
                l.release()
#   print (num)

def put_money(num,l):
        for i in range(100):
                l.acquire()
                num[0]=num[0]+1
                l.release()
#   print (num)
if __name__=='__main__':
        m=Manager()
        num=m.list([1,2,3])
        l=Lock()
        p=Process(target=get_money,args=(num,l,))
        p.start()
        p1=Process(target=put_money,args=(num,l))
        p1.start()
        p.join()
        p1.join()
        print (num)
#结果输出
[1, 2, 3]

生产者和消费者模型(必会)

from  multiprocessing import Process,Queue
import time

def producer(q):
        for i in range(1,5):
                q.put(i)
                print ("produce %s"%i)
                time.sleep(1)
        q.put(None)                        #添加None是为了当消费者消费了队列中所有值以后可以正常退出

def consumer(q):

        while 1:
                result=q.get()
                if result:
                        print ("consume %s"%result)
                else:
                        break
if __name__=='__main__':
        q=Queue()
        p=Process(target=producer,args=(q,))
        p1=Process(target=consumer,args=(q,))
        p.start()
        p1.start()
        p.join()
        p1.join()
#结果输出
produce 1
consume 1
produce 2
consume 2
produce 3
consume 3
produce 4
consume 4

进程池

from multiprocessing import Pool,Process
import os
import time
def worker():
        for i in range(1000000):
                i=i+1
#       print (os.getpid())

if __name__=="__main__":
        start=time.time()
        p=Pool(10)
        for i in range(100):
                p.apply_async(worker) 
        p.close()
        p.join()
        end=time.time()
        print ("进程池时间:",start-end)

        start1=time.time()
        p_l=[]
        for j in range(100):
                p=Process(target=worker)
                p.start()
                p_l.append(p)
        [i.join() for i in p_l]
        end1=time.time()
        print ("手动创建进程时间:",start1-end1)
#结果输出
进程池时间: -3.6715526580810547
手动创建进程时间:  -9.386803388595581
上一篇下一篇

猜你喜欢

热点阅读