重拾Python第二十二天(进程与线程)

1.进程

1.1 特点

  • 系统实施资源分配和调度的一个最小独立单位
  • 进程之间相互独立(主进程与子进程,子进程与子进程间都不能通信),同一个数据变量,各进程在执行时都会保存自己的一份,互不影响
  • 进程的独立性使得一个进程的崩溃不会影响其他进程(浏览器崩溃,其他进程比如word、ecxel和PPT等不会出现问题)

1.2 创建方式

  • os.fork():仅支持Linus系统
  • multiprocessing模块Process类
# 使用Process类创建2个子进程,并记录子进程运行时间
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,)) # 创建进程实例,target表示当前进程启动时执行的可调用对象,name为该子进程实例名称,args表示传递给target函数的参数元组(休眠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 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值