zoukankan      html  css  js  c++  java
  • python 进程Process模块(40)

        进程Process是对各种资源管理的集合,包含对各种资源的调用、内存的管理、网络接口的调用;一个进程Process可以包含多个子进程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程就是主线程(即python __name__ == ‘__main__’);

     

    二.进程Process模块

    对于线程操作可以用threading模块,那么对于进程的创建python同样也提供了Process模块,创建进程时需要导入该模块,语法如下:

    参数介绍:

        group — 参数未使用,默认值为None;

        target — 表示调用对象,即子进程要执行的任务(函数名字);

        args — 子进程对应函数的参数,并且类型是元组tuple;

        kwargs — 子进程对应函数的参数,并且类型是字典dict,如kwargs = {‘name’:Jack, ‘age’:18};

        name — 子进程名称;

        返回值:返回进程实例对象;

     

    三.进程Process函数介绍

       其实进程Process的函数和线程threading类似,具体如下:

        1.start() — 启动进程;

        2.terminate() — 强制终止进程,不会进行任何清理操作。如果该进程终止前,创建了子进程,那么该子进程在其强制结束后变为僵尸进程;如果该进程还保存了一个锁那么也将不会被释放,进而导致死锁,使用时,要注意;

        3.is_alive() — 判断某进程是否存活,存活返回True,否则False;

        4.join([timeout]) — 主线程等待子线程终止。timeout为可选择超时时间;需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程 ;

        5.daemon — 默认值为False,如果设置为True,代表该进程为后台守护进程;当该进程的父进程终止时,该进程也随之终止;并且设置为True后,该进程不能创建子进程,设置该属性必须在start()之前;

        6.name — 进程名称;

        7.pid— 进程ID标识,pid,值得注意的是:如果在start函数之前获取pid默认为None,因为进程还未创建,获取不到pid;

        8.exitcode — 进程运行时为None,如果为-N,表示被信号N结束了;

        9.authkey — 进程身份验证,默认是由os.urandom()随机生成32字符的字符串。这个键的用途是设计涉及网络连接的底层进程间的通信提供安全性,这类连接只有在具有相同身份验证才能成功;

     

     

    四.进程Process使用

    # !usr/bin/env python
    # -*- coding:utf-8 _*-
    """
    @Author:何以解忧
    @Blog(个人博客地址): shuopython.com
    @WeChat Official Account(微信公众号):猿说python
    @Github:www.github.com
     
    @File:python_process.py
    @Time:2019/12/21 21:25
     
    @Motto:不积跬步无以至千里,不积小流无以成江海,程序人生的精彩需要坚持不懈地积累!
    """
     
    from multiprocessing import Process
     
     
    def people_info(*args,**kwargs):
        print(args,kwargs)
     
     
     
    def main():
     
        # 信息列表
        list_info = [{"name":"zhangsan","height":"175cm"},
                     {"name": "lisi", "height": "155cm"},
                     {"name": "wangwu", "height": "195cm"},
                     {"name": "liqi", "height": "166cm"},
                     {"name": "wangba", "height": "125cm"},]
     
        # 创建进程
        for i in range(5):
            p = Process(target=people_info,args=(i,),kwargs=list_info[i])
            # 设置为守护进程,必须设置在start函数之前,否则会产生异常
            # 默认为False,即主进程会等待子进程结束之后才结束,
            # 如果设置为True,主进程结束之后所有的子进程自动结束,不管子进程是否已经执行完所有任务
            # p.daemon = True
     
            # 启动进程
            p.start()
     
            # 获取进程pid,如果在start函数之前获取pid,默认为None,因为进程还没启动
            print("进程process pid = ",p.pid)
            # 获取进程名字
            print("进程process name = ",p.name)
            # 获取进程pid
            print("进程process exitcode = ",p.exitcode)
     
     
     
     
    if __name__ == "__main__":
        main()

    输出结果:

    进程process pid =  2600
    进程process name =  Process-1
    进程process exitcode =  None
    进程process pid =  4372
    进程process name =  Process-2
    进程process exitcode =  None
    进程process pid =  14124
    进程process name =  Process-3
    进程process exitcode =  None
    进程process pid =  10920
    进程process name =  Process-4
    进程process exitcode =  None
    进程process pid =  4892
    进程process name =  Process-5
    进程process exitcode =  None
    (0,) {'name': 'zhangsan', 'height': '175cm'}
    (1,) {'name': 'lisi', 'height': '155cm'}
    (2,) {'name': 'wangwu', 'height': '195cm'}
    (3,) {'name': 'liqi', 'height': '166cm'}
    (4,) {'name': 'wangba', 'height': '125cm'}

     

    小窍门:

    Python 的 os 模块封装了常见的系统调用,其中就包括:

     

        关于进程Process创建就介绍到这里,不知道大家发现没有,进程process的创建和线程threading的创建非常相似,那么python进程和线程到底又有什么区别呢?关于python进程和线程的区别请参考:

    python进程Process与线程threading的区别

     

     

     

     

    猜你喜欢:

        1.python 线程threading模块

        2.python 线程互斥锁Lock

        3.python 线程事件Event

        4.python 线程定时器Timer

     

        转载请注明:猿说Python » python 进程Process模块

     

    技术交流、商务合作请直接联系博主
    扫码或搜索:猿说python
    python教程公众号
    猿说python
    微信公众号 扫一扫关注
  • 相关阅读:
    UIAction 公共界面访问控制(拦截控制)
    MD5加密
    SVN的简单用法
    Spring AOP基础之JDK动态代理
    Spring中的事务管理模块基础
    Spring添加Junit4支持
    Spring里面dbcp连接池的配置和使用
    vue.js自定义指令详解
    vue input输入框联想
    export ,export default 和 import 区别 以及用法
  • 原文地址:https://www.cnblogs.com/shuopython/p/12257987.html
Copyright © 2011-2022 走看看