1.进程
1.1 特点
- 系统实施资源分配和调度的一个最小独立单位
- 进程之间相互独立(主进程与子进程,子进程与子进程间都不能通信),同一个数据变量,各进程在执行时都会保存自己的一份,互不影响
- 进程的独立性使得一个进程的崩溃不会影响其他进程(浏览器崩溃,其他进程比如word、ecxel和PPT等不会出现问题)
1.2 创建方式
- os.fork():仅支持Linus系统
- multiprocessing模块Process类
import os
import time
from multiprocessing import Process
def main_process():
print('主进程开始')
print('主进程PID:%s' % (os.getpid()))
p1 = Process(target=child_process1, name='nl_flw1', args=(2,))
p2 = Process(target=child_process2, name='nl_flw2', args=(1,))
p1.start()
p2.start()
print('p1.is_alive=%s' % (p1.is_alive()))
print('p2.is_alive=%s' % (p2.is_alive()))
print('p1.name=%s' % p1.name)
print('p1.pid=%s' % p1.pid)
print('p2.name=%s' % p2.name)
print('p2.pid=%s' % p2.pid)
p1.join()
p2.join()
print('主进程结束')
def child_process1(interval):
print('子进程(%s)开始执行,父进程是(%s)' % (os.getpid(), os.getppid()))
child_process1_start = time.time()
time.sleep(interval)
child_process1_end = time.time()
print('子进程(%s)执行了(%0.2f)秒' % (os.getpid(), child_process1_end-child_process1_start))
def child_process2(interval):
print('子进程(%s)开始执行,父进程是(%s)' % (os.getpid(), os.getppid()))
child_process2_start = time.time()
time.sleep(interval)
child_process2_end