• python进程基础点整理


    操作系统


    1. 串行: 一个程序完完整整的执行完再执行下一个
    2. 并发: 看起来像是同时运行,其实就是程序间的切换频率比较快,看不出来
    3. 并行:真正的同时运行

    多道技术


    1. 空间复用:共用一个内存条,多个进程相互隔离,物理级别隔离
    2. 时间复用: 共用一个CPU

    阻塞和非阻塞


    程序运行的三个状态:

    就绪(ready)
    运行(run)
    阻塞(blocked)167-同步异步阻塞非阻塞-01.png?x-oss-process=style/watermark

    167-同步异步阻塞非阻塞-02.png?x-oss-process=style/watermark


    开启子进程,申请新的内存空间,把父进程的所有代码,完整的拷贝一份过去,这就是子进程

    from multiprocessing import Process
    
    def task(x):
        pass
    
    if __name__ == '__main__':
        p = Process(target=task,args=(45,))
        p.start()
    

    开始子进程方式二(不常用)

    class Xx(Process):
        def __init__(self,x):
            super().__init__()
            self.x = x
        def run(self):
            pass
    
    if __name__ == '__main__':	
    	p = Xx()
    	p.start()
    

    验证内存空间彼此隔离

    from multiprocessing import Process
    import time
    
    x=0
    def task():
        global x
        x= 100
        print('子进程的x修改为了{}'.format(x))
    
    if __name__ == '__main__':
        p = Process(target=task)
        p.start()
        time.sleep(5)
        print(x)
    

    僵尸进程:

    ​ 父进程的子进程 结束的时候,父进程没有对子进程进行pid回收(wait())的情况下进程会变成僵尸进程

    补充:父进程等着所有子进程结束才会结束

    孤儿进程(无害):

    ​ 一个父进程退出,而它的一个或多个子进程还在运行,那么这些子进程将成为孤儿进程,孤儿进程将被Init进程(进程号为1)所回收,并由init进程对它们完成状态收集工作。

    分析三种情况:

    情况一: 无害
    父进程等着子进程结束完后,回收僵尸进程

    情况二 : 无害
    父进程死了,子进程还在运行,都要被init进程接管并且回收

    情况三: 有害
    父进程一直不死,造成大量僵尸进程,占用了大量的Pid号

    由于pid号是有限的,最直接的办法是直接杀死父进程

  • 相关阅读:
    J2ME学习笔记之问题看法
    单词王(kingWord)
    TCP的粘包和拆包问题及解决办法(C#)
    vuex里mapState,mapGetters使用详解
    agelform formcreate 使 elementui form 组件更简单
    elementui 二次封装系列 button
    开源一套后台管理系统框架,远离996 记录
    客户端架构介绍
    简单的Unity学习项目,封装了一下简单、通用功能组件,适用于数据可视化展示
    Vue关于对象数组的双向数据绑定(props与watch)
  • 原文地址:https://www.cnblogs.com/guapitomjoy/p/11514769.html
Copyright © 2020-2023  润新知