进程的状态和进程之间的通信

进程的状态:

在程序运行的过程中,由于操作系统的调度算法控制,程序会进入几个状态:就绪,运行和阻塞。进程状态放映进程执行过程的变化,这些状态随着进程的执行和外界条件的变化而转换。一个进程的生命周期可以划分为一组状态,这些刻画了整个进程。进程状态即体现了一个进程的生命状态。
在这里插入图片描述

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() 判断队列是否存放满了

在这里插入图片描述
做人不可以太低下,因为父亲曾经把你举过头顶。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乌拉的故事

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值