运行环境:Ubuntu16.04 (fork在Windows系统里不能使用)
进程(process)
进程理论基础
定义 : 程序在计算机中的一次运行。
程序是一个可执行的文件,是静态的占有磁盘。
进程是一个动态的过程描述,占有计算机运行资源,有一定的生命周期。
系统中如何产生一个进程【1】 用户空间通过调用程序接口或者命令发起请求【2】 操作系统接收用户请求,开始创建进程【3】 操作系统调配计算机资源,确定进程状态等【4】 操作系统将创建的进程提供给用户使用
进程基本概念
cpu时间片:如果一个进程占有cpu内核则称这个进程在cpu时间片上。
PCB(进程控制块):在内存中开辟的一块空间,用于存放进程的基本信息,也用于系统查找识别进程。
进程ID(PID): 系统为每个进程分配的一个大于0的整数,作为进程ID。每个进程ID不重复。
Linux查看进程ID : ps -aux
父子进程 : 系统中每一个进程(除了系统初始化进程)都有唯一的父进程,可以有0个或多个子进程。父子进程关系便于进程管理。
查看进程树: pstree
进程状态
三态就绪态 : 进程具备执行条件,等待分配cpu资源运行态 : 进程占有cpu时间片正在运行等待态 : 进程暂时停止运行,让出cpu
五态 (在三态基础上增加新建和终止)新建 : 创建一个进程,获取资源的过程终止 : 进程结束,释放资源的过程
状态查看命令 : ps -aux --> STAT列
S 等待态
R 执行态
Z 僵尸
`+` 前台进程
l 有多线程的
进程的运行特征【1】 多进程可以更充分使用计算机多核资源【2】 进程之间的运行互不影响,各自独立【3】 每个进程拥有独立的空间,各自使用自己空间资源
基于fork的多进程编程
fork使用
pid = os.fork()功能: 创建新的进程返回值:整数,如果创建进程失败返回一个负数,如果成功则在原有进程中返回新进程的PID,在新进程中返回0
注意
子进程会复制父进程全部内存空间,从fork下一句开始执行。
父子进程各自独立运行,运行顺序不一定。
利用父子进程fork返回值的区别,配合if结构让父子进程执行不同的内容几乎是固定搭配。
父子进程有各自特有特征比如PID PCB 命令集等。
父进程fork之前开辟的空间子进程同样拥有,父子进程对各自空间的操作不会相互影响。
代码:
"""
fork.py fork进程创建演示
"""
import os
from time import sleep
# 创建子进程
pid = os.fork()
if pid < 0:
print("Create process failed")
elif pid == 0:
# 只有子进程执行
sleep(3)
print("The new process")
else:
# 只有父进程执行
sleep(4)
print("The old process")
# 父子进程都执行
print("process test over")
代码:
"""
fork1.py fork进程演示细节
"""
import os
from time import sleep
print("=========================")
a = 1
def fun():
print("fun .... ")
pid = os.fork()
if pid < 0:
print("Create process failed")
elif pid == 0:
print("Child process")
print("a = ",a) # 从父进程空间拷贝了变量
fun()
a = 10000 # 只是修改了自己空间的a
else:
sleep(1)
print("Parent process")
print("a:",a)
print("All a ->",a)
进程相关函数
os.getpid()功能: 获取一个进程的PID值返回值: 返回当前进程的PID
os.getppid()功能: 获取父进程的PID号返回值: 返回父进程PID
os._exit(status)功能: 结束一个进程参数:进程的终止状态
sys.exit([status])功能:退出进程参数:整数 表示退出状态字符串 表示退出时打印内容
代码示例:get_pid.py
"""
获取进程PID号
"""
import os
from time import sleep
pid = os.fork()
if pid < 0:
print("Error")
elif pid == 0:
sleep(1)
print("Child PID:",os.getpid()) # 自己pid
print("Get parent PID:",os.getppid()) # 父pid
else:
print("Parent PID:", os.getpid()) # 自己pid
print("Get child PID:",pid)
代码示例:exit.py
"""
进程退出演示
"""
import os,sys
pid = os.fork()
# 父子进程退出不会影响对方继续执行
if pid < 0:
print("Error")
elif pid == 0:
# os._exit(0) # 子进程退出
print("Child process")
else:
sys.exit("退出父进程")
print("Parent process")