python进程(1)简单使用

在python中使用进程的时候是使用的是multiprocessing库。
下面简单总结python中的进程符合创建以及使用。

1、process进程类的说明

(1) Process([group[,target[,name[,args[,kwargs]]]]])
参数说明:

  • group:指定进程组,目前只能使用None
  • target:进程执行目标的任务名
  • name:进程名称
  • args:以元组方式对执行任务进行传参
  • kwargs:以字典方式给执行任务进行传参

(2) Process创建实例对象的常用方法:

  • start():启动子进程的实例(创建子进程)
  • join():等待子进程执行结束
  • terminate():无论任务是否完成,立即终止子进程

(3) process进程实例

  • 创建子进程完成跳舞任务,主进程执行唱歌任务:(注意,进程必须在main方法中启用,即在__main__中启动)
# 1、导入进程包
import multiprocessing
import time

# 跳舞任务
def dance():
    for i in range(3):
        print('正在跳舞中......')
        time.sleep(0.3)
# 唱歌任务
def sing():
    for i in range(3):
        print('正在唱歌中......')
        time.sleep(0.4)

# 2、实例化子进程
dance_process = multiprocessing.Process(target=dance)


if __name__ == '__main__':


    # 3、启动子进程,去执行对应的任务
    dance_process.start()

    # 主进程执行唱歌任务
    sing()


运行结果:
正在唱歌中......
正在唱歌中......
正在跳舞中......
正在跳舞中......
正在唱歌中......
正在跳舞中......
  • 唱歌和跳舞任务都使用子进程来执行
# 1、导入进程包
import multiprocessing
import time

# 跳舞任务
def dance():
    for i in range(3):
        print('正在跳舞中......')
        time.sleep(0.3)
# 唱歌任务
def sing():
    for i in range(3):
        print('正在唱歌中......')
        time.sleep(0.4)

# 2、实例化子进程
dance_process = multiprocessing.Process(target=dance)
sing_process = multiprocessing.Process(target=sing)

if __name__ == '__main__':


    # 3、启动子进程,去执行对应的任务
    dance_process.start()

    # 子进程执行唱歌任务
    sing_process.start()

运行结果:
正在跳舞中......
正在唱歌中......
正在跳舞中......
正在唱歌中......
正在跳舞中......
正在唱歌中......

进程执行是无序的,具体哪个及产能先执行是由操作系统调度决定的。

2、获取进程的编号

(1) 获取进程编号的目的
获取进程编号的目的是为了验证主进程和子进程之间的关系,可以得知子进程是由哪一个主进程创建的。
操作步骤:获取当前进程的编号,通过该进程获取父进程的编号,如果获取到父进程的编号是当前主进程的编号,那么该子进程就是该主进程创建的。

(2) 获取当前进程的编号

  • os.getpid():获取当前进程的id
  • os.getppid():获取当前进程的父进程的id
  • multiprocessing.current_process():获取当前进程的进程对象
# 1、导入进程包
import multiprocessing
import time
import os

# 跳舞任务
def dance():
    # 获取当前dance程序进程的id
    dance_process_id = os.getpid()

    # 获取当前dance程序进程对象
    dance_process_obj = multiprocessing.current_process()
    print('dance进程的对象:%s, dance进程的id:%s' %(dance_process_obj, dance_process_id))

    # 获取当前dance程序进程的父进程id
    dance_process_parent_id = os.getppid()
    print('dance程序进程的父进程的id:', dance_process_parent_id)

    for i in range(3):
        print('正在跳舞中......')
        time.sleep(0.3)


# 唱歌任务
def sing():
    # 获取当前sing程序进程的id
    sing_process_id = os.getpid()

    # 获取当前sing程序进程对象
    sing_process_obj = multiprocessing.current_process()
    print('sing进程的对象:%s, sing进程的id:%s' %(sing_process_obj, sing_process_id))

    # 获取当前sing程序进程的父进程id
    sing_process_parent_id = os.getppid()
    print('sing程序进程的父进程的id:', sing_process_parent_id)

    for i in range(3):
        print('正在唱歌中......')
        time.sleep(0.4)

# 2、实例化子进程
dance_process = multiprocessing.Process(target=dance, name="dance_process")
sing_process = multiprocessing.Process(target=sing, name="sing_process")

if __name__ == '__main__':


    # 3、启动子进程,去执行对应的任务
    dance_process.start()

    # 子进程执行唱歌任务
    sing_process.start()

    # 获取当前main程序进程的id
    main_process_id = os.getpid()
    print('当前main程序进程的id:',main_process_id)

    # 获取当前main程序进程对象
    main_process_obj = multiprocessing.current_process()
    print('当前main程序进程对象:',main_process_obj)


运行结果:
当前main程序进程的id: 7032
当前main程序进程对象: <_MainProcess(MainProcess, started)>
dance进程的对象:<Process(dance_process, started)>, dance进程的id:1392
dance程序进程的父进程的id: 7032
正在跳舞中......
sing进程的对象:<Process(sing_process, started)>, sing进程的id:2104
sing程序进程的父进程的id: 7032
正在唱歌中......
正在跳舞中......
正在唱歌中......
正在跳舞中......
正在唱歌中......

由结果看出,sing子程序和dance子程序都是由主程序MainProcess创建的。

**(3)**杀死指定进程
os.kill(process_id,sig):process_id为要杀死的指定进程的id,sig为操作状态:操作(第二个参数)的常用取值为:

  • SIGINT 终止进程 中断进程
  • SIGTERM 终止进程 软件终止信号
  • SIGKILL 终止进程 杀死进程
  • SIGALRM 闹钟信号
# 1、导入进程包
import multiprocessing
import time
import os
import signal

# 跳舞任务
def dance():
    # 获取当前dance程序进程的id
    dance_process_id = os.getpid()

    # 获取当前dance程序进程对象
    dance_process_obj = multiprocessing.current_process()
    print('dance进程的对象:%s, dance进程的id:%s' %(dance_process_obj, dance_process_id))

    # 获取当前dance程序进程的父进程id
    dance_process_parent_id = os.getppid()
    print('dance程序进程的父进程的id:', dance_process_parent_id)

    for i in range(3):
        print('正在跳舞中......')
        time.sleep(0.3)

        os.kill(dance_process_id, signal.SIGKILL)


# 唱歌任务
def sing():
    # 获取当前sing程序进程的id
    sing_process_id = os.getpid()

    # 获取当前sing程序进程对象
    sing_process_obj = multiprocessing.current_process()
    print('sing进程的对象:%s, sing进程的id:%s' %(sing_process_obj, sing_process_id))

    # 获取当前sing程序进程的父进程id
    sing_process_parent_id = os.getppid()
    print('sing程序进程的父进程的id:', sing_process_parent_id)

    for i in range(3):
        print('正在唱歌中......')
        time.sleep(0.4)

# 2、实例化子进程
dance_process = multiprocessing.Process(target=dance, name="dance_process")
sing_process = multiprocessing.Process(target=sing, name="sing_process")

if __name__ == '__main__':


    # 3、启动子进程,去执行对应的任务
    dance_process.start()

    # 子进程执行唱歌任务
    sing_process.start()

    # 获取当前main程序进程的id
    main_process_id = os.getpid()
    print('当前main程序进程的id:',main_process_id)

    # 获取当前main程序进程对象
    main_process_obj = multiprocessing.current_process()
    print('当前main程序进程对象:',main_process_obj)

运行结果:
当前main程序进程的id: 2044
当前main程序进程对象: <_MainProcess(MainProcess, started)>
dance进程的对象:<Process(dance_process, started)>, dance进程的id:9404
sing进程的对象:<Process(sing_process, started)>, sing进程的id:10940
dance程序进程的父进程的id: 2044
正在跳舞中......
sing程序进程的父进程的id: 2044
正在唱歌中......
正在唱歌中......
正在唱歌中......

由此可以看出dance进程已经被杀死。

上一篇:Python_并发编程总结


下一篇:Python3 多线程与互斥锁