python进程

Posted bobby

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python进程相关的知识,希望对你有一定的参考价值。

进程                                                                                                                     

进程是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源费配和调度的基本单位,是操作系统结构的基础。在当代面向线程设计的计算机结构中,进程是线程的容器,同一个进程中的多个线程可以共享其资源,而进程与进城之间可以起到数据隔离的作用(即同一个程序执行两次,就会在操作系统出现两个进程,所以同时运行同一个软件做不同的事情也不会混乱)。

进程的并行和并发                                                                                                                       

并行:是指两者同时进行,微观上,就是在一个时刻,有不同的程序执行,要求必须有多个处理器。

并发:是指系统资源有限,两者只能交替轮流使用资源,目的是为了提高效率,从宏观上看某个时刻是同时进行的。

同步、异步、                                                                                                     

 同步和异步:       

  同步就是一个任务的完成需要依赖另一个任务时,只有等待被依赖的任务完成后,依赖的任务才算完成,这是一种可靠的任务序列。成功都成功,失败都失败,两个任务的 状态保持一致。

        异步(回调机制)是不需要等待被依赖的任务完成,只是通知被依赖的任务要完成什么操作,依赖的任务也立即执行,自己完成了整个任务就算完成了。至于被依赖的任务是否完成,依赖他的任务无法确定,所以这是一种不可靠的任务序列。

  使用process模块创建进程           

技术分享图片
import time
from multiprocessing import Process

def f(n):    
    print(n)
    print(子进程)

if __name__ == __main__:
    p = Process(target=f, args=(666,))
    p.start()
    time.sleep(1)
    print(主进程)
创建子进程
技术分享图片
import time
from multiprocessing import Process

def f(name):
    print(hello, name)
    time.sleep(1)
    print(子进程)
if __name__ == __main__:
    p = Process(target=f, args=(bob,))
    p.start()
    p.join()
    print(父进程)
join

继承创建进程:

技术分享图片
def task(n):
    n+=1
    print(n)
if __name__ == __main__:
    for i in range(3):
        p=Process(target=task,args=(i,))
        p.start()
View Code

进程之间的数据隔离:

技术分享图片
class MyProcess(Process):
    def __init__(self,name):
        super().__init__()
        self.name=name
    def run(self):
        print(os.getpid())
        print(self.name)
if __name__ == __main__:

    p1=MyProcess(messi)
    p2=MyProcess(c罗)
    p3=MyProcess(salah)

    p1.start() #start会自动调用run
    p2.start()
    p3.start()

    p1.join()
    print(os.getppid())
View Code

进程之间的数据共享:

进程池

 

  

 

以上是关于python进程的主要内容,如果未能解决你的问题,请参考以下文章

[Python3] 043 多线程 简介

java 简单的代码片段,展示如何将javaagent附加到运行JVM进程

代码片段:Shell脚本实现重复执行和多进程

python中的多线程和多进程编程

使用 asyncio 将 bash 作为 Python 的子进程运行,但 bash 提示被延迟

LINUX PID 1和SYSTEMD PID 0 是内核的一部分,主要用于内进换页,内核初始化的最后一步就是启动 init 进程。这个进程是系统的第一个进程,PID 为 1,又叫超级进程(代码片段