进程的状态:
在程序运行的过程中,由于操作系统的调度算法控制,程序会进入几个状态:就绪,运行和阻塞。进程状态放映进程执行过程的变化,这些状态随着进程的执行和外界条件的变化而转换。一个进程的生命周期可以划分为一组状态,这些刻画了整个进程。进程状态即体现了一个进程的生命状态。
1.就绪(Ready):
进程已获得除处理器外的所需资源,只是在等待分配资源,只要分配了处理器进程就可以执行。
准备就绪过程可以按多个优先级来划分队列,例如:当一个进程由于时间片用完而进入就绪状态时,排入第优先级队列。当进程由I/O操作完成而进入就绪状态时,排入高优先级队列。
2.运行(Running):
进程占用处理器资源,出于此状态的进程的数目小于或等于处理器的数目,在没有其他进程可以执行时(例如所有进程都在阻塞状态),系统通常会自动执行系统的空闲进程。
3.阻塞(Blocked):
系统由于进程等待某种条件(如I/O操作或进程同步),在条件满足之前无法继续执行。该事件发生前即使把处理器资源分配给了该进程,该进程也无法继续运行。
状态转换:
就绪------>执行:
处于就绪状态的进程,当进程调度程序为止分配了处理机之后,该进程就由就绪状态转变为执行状态。当运行进程堵塞,调度程序选一个优先级最高的进程占有处理机。
执行------>就绪:
处于执行状态的进程在其执行过程中,因分配给他的一个事件片已用完而不得不让出处理机,于是进程从执行状态变成就绪状态。
执行------>堵塞:
正在执行的进程因等待某种事件发生而无法继续执行时,便从执行状态变成堵塞状态。
堵塞------>就绪:
处于堵塞状态的进程,若其等待的事件已经发生,于是进程由堵塞状态装变为就绪状态。
进程间的通讯——Queue:
我们知道进程multiprocessing 模块的Queue实现多进程之间的数据传递,Queue本身是一个消息队列程序。
put()方法:
from multiprocessing import Queue(3)
#创建队列,指定最大容量,若不指定则为无限大。
q = put("A")
q = puy("B")
q = put("C")
#队列已满,此时程序将被阻塞,直到流出空间为止
q = put("D")
get()方法:
from multiprocessing import Queue(3)
#创建队列,指定最大容量,若不指定则为无限大。
q = put("A")
q = puy("B")
q = put("C")
#队列已满,此时程序将被阻塞,直到流出空间为止
q = put("D")
q = get() # "A"
q = get() # "B"
q = get() # "C"
#队列为空,程序阻塞,直到新数据的加入
q =get()
使用Queue:
在父进程中写两个子进程,一个做写入操作,一个读取。
from multiprocessing import Process, Queue
import time
import random
# 写数据进程
def write(q):
for value in ["A", "B", "C"]:
print("写入%s进Queue.." % value)
q.put(value)
time.sleep(random.random())
# 读数据进程
def read(q):
while True:
if not q.empty():
value = q.get()
print("获取%s在Queue" % value)
time.sleep(random.random())
else:
break
if __name__ == '__main__':
# 父进程创建Queue,传给各个子进程
q = Queue()
pw = Process(target=write, args=(q,))
pr = Process(target=read, args=(q,))
# 启动子进程
pw.start()
# 等待写数据的子进程结束
pw.join()
pr.start()
pr.join()
print("所有数据都写完并且读完")
q.qsize(),获取队列长度(队列中的数据数量)
get_nowait() 抛异常
empty()判断队列是否空了 True表示空了
full() 判断队列是否存放满了
做人不可以太低下,因为父亲曾经把你举过头顶。