Python并发编程3——multiprocessing模块创建进程

multiprocessing 模块创建进程

进程创建方法

  1. 流程特点
    【1】 将需要子进程执行的事件封装为函数
    【2】 通过模块的Process类创建进程对象,关联函数
    【3】 可以通过进程对象设置进程信息及属性
    【4】 通过进程对象调用start启动进程
    【5】 通过进程对象调用join回收进程

  2. 基本接口使用

Process()
功能 : 创建进程对象
参数 : target 绑定要执行的目标函数 
	args 元组,用于给target函数位置传参
	kwargs 字典,给target函数键值传参
p.start()
功能 : 启动进程

注意:启动进程此时target绑定函数开始执行,该函数作为子进程执行内容,此时进程真正被创建

p.join([timeout])
功能:阻塞等待回收进程
参数:超时时间

注意

  • 使用multiprocessing创建进程同样是子进程复制父进程空间代码段,父子进程运行互不影响。
  • 子进程只运行target绑定的函数部分,其余内容均是父进程执行内容。
  • multiprocessing中父进程往往只用来创建子进程回收子进程,具体事件由子进程完成。
  • multiprocessing创建的子进程中无法使用标准输入


    '''
        multiprocessing进程示例
    '''

    import multiprocessing as mp
    from time import sleep


    def fun():
        print("子进程开始执行")
        sleep(3)
        print("子进程执行完毕")


    print("父进程开始执行")

    # 创建进程对象
    p = mp.Process(target=fun)

    # 启动进程

    p.start()

    # 回收进程

    p.join()

    print("父进程执行完毕")


    '''
        批量回收子进程
    '''

    import multiprocessing as mp
    from time import sleep


    def th1():
        sleep(1)
        print("吃饭")


    def th2():
        sleep(2)
        print("睡觉")


    def th3():
        sleep(3)
        print("打豆豆")


    things = [th1, th2, th3]
    jobs = []


    for th in things:
        p = mp.Process(target = th)
        jobs.append(p)
        p.start()

    for i in jobs:
        i.join()


    '''
        给进程函数传参
    '''
    from multiprocessing import Process

    from time import sleep

    def worker(sec,name):
        for i in range(3):
            sleep(sec)
            print("I`m %s"%name)
            print("I`m working......")

    p = Process(target=worker,args=(2,'Xiaoming'))
    p = Process(target=worker,kwargs={'name':"Abby",'s':2})
    p.start()

    p.join()

  1. 进程对象属性

p.name 进程名称

p.pid 对应子进程的PID号

p.is_alive() 查看子进程是否在生命周期

p.daemon 设置父子进程的退出关系

  • 如果设置为True则子进程会随父进程的退出而结束
  • 要求必须在start()前设置
  • 如果daemon设置成True 通常就不会使用 join()

	'''
		进程对象属性
	'''   
    from multiprocessing import Process
    from time import sleep,ctime

    def tm():
        for i in range(3):
            sleep(2)
            print(ctime())

    p = Process(target = tm,name = "Tedu")

    # 子进程随父进程退出
    p.daemon = True

    p.start()
    print("Name:",p.name)  # 获取名称
    print("PID:",p.pid)    # 获取PID
    print("is Alive:",p.is_alive()) # 是否在生命周期


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值