知识点一:进程的理论
进程:正在进行的一个程序或者说一个任务,而负责执行任务的则是CPU
进程运行的的三种状态:
1.运行:(由CPU来执行,越多越好,可提高效率)
2.阻塞:(遇到了IQ,3个里面可以通过减少阻塞有效的来提高效率)
3.就绪:(等待CPU来执行的过程)

知识点二:开启进程的两种方式

  开启进程:开启进程就是将父进程里面串行执行的程序放到子进程里,实现并发执行,这个过程中,会将父进程数据拷贝一份到子进程。
  运行角度:是2个进程
  注意:子进程内的初始数据与父进程的一样,如果子进程被创建了被运行了,那么
     子进程里面数据更改对父进程无影响,2个进程是存在运行的

方式一:通过调用multiprocessing模块下面的Process类方法

#方式一:通过调用multiprocessing模块下面的Process类方法

'''
p = Process(target=task, args=('子进程',)) :
target=task:指定执行任务的目标是谁 args:后面跟元组,是给target指定函数传的参数
p=Process(..)相当于是对类Process进行实例化得到了P对象
'''
from multiprocessing import Process
import time
def task(x):
print("%s is runnin"%x) #子进程打印输出
time.sleep(3)
print('%s is done'%x) #子进程打印输出 if __name__ == '__main__': #开进程要统一放到main方法的下面
p=Process(target=task,args=('子进程',))
p.start()
print('主') #父进程的打印输出 '''
注意点:
1.p=Process(target=task,args=('子进程',))
这一步:只是在向操作系统发我要开启一个子进程的信号(具体开子进程的操作是由操作系统来完成的)
*所有这个过程中的时间也是不固定的
2.p.start():
开启一个子进程 运行过程分析:
右键运行父类先运行起来(此时p.start()子类也已经在造了,但是会有时间延迟)-->print('主')-->
然后依次运行子进程里面内容;子进程 is runnin\子进程 is done '''

方式二:借助process类,自定义一个类(继承Process),从而造一个对象

#方式二:借助process类,自定义一个类(继承Process),从而造一个对象
from multiprocessing import Process
import time class Myprocess(Process):
#辅助理解,
# def __init__(self,x):
# super().__init__()#保留原有Process类里面的方法
# self.name=x #***如果要自定义传参,self.name=x必须要放到super()._init_()下面
#
def run(self):
print("%s is running" % self.name) #默认函数对象有name方法 ,结果为:Myprocess-1
time.sleep(3)
print('%s is done' % self.name) if __name__ == '__main__':
# p=Myprocess('子进程1',) 开启init方式就可以自定义参数传值
p=Myprocess() #实例化Myprocess类调用了类面的init方法,得到了一个对象p p1=Myprocess() p.start() #p.run() 对象去调用了类里面的run方法,进而执行run里面的函数体代码
p1.start()
print('主')

以上2中方式的对比分析:

方式二:子类只能运行同一个run里面输出的方式(run名字是固定的,不能更改)

方式一:可以自定义多个task函数,并且写不同的输出内容,例如task1-->p1 task2-->p2...等等灵活性更高

 

父类、子类进程内存空间是彼此隔离的:

from multiprocessing import Process
import time x=100
def task():
global x
x=11 #当子类已经建立成功时,子类里面对数据的变动,不会印象父类
print(x) #
print('done')
if __name__ == '__main__':
p=Process(target=task)
p.start()
time.sleep(10) # 让父进程在原地等待10,是为了等父类先建立好,用于验证子类里面的变动不会影响父类的值
print(x) #打印时父类的,即全局的 100

 

 知识点三:僵尸进程、孤儿进程

  僵尸进程:(无害的)
  子进程运行结束后,会保留进程的ID号等信息,
  目的是为了父进程能查看子进程的状态,以及回收僵尸状态的子进程

  孤儿进程:(无害的)
  在子类没有运行完的情况下,父类先行结束,这种情况下,当子进程结束时,
  状态就叫做孤儿进程,当然也会被系统层面上的孤儿院回收

  有一种情况是有害的:
  如果父类,不停的在造子类,父类一直不死,此时PID会占用过多,导致内存也会占用很多
  这种情况是有害的

 知识点四:进程对象相关的属性

1.PID接口查看

#查看PID应用:
# print(p.pid):外面直接查看子类pid
#os.getpid():在内部查看子类pid
#os.getpid():在外面查看父类的pid
#os.getppid():在里面查看父类的pid
import time
import os
from multiprocessing import Process def task(x): print('%s is running'%os.getpid()) #子进程内查看自己pid的方式
time.sleep(100)
print('子类下查看父类的id:%s'%os.getppid()) #查看父类的pid
time.sleep(100)
print('%s is done'%x) if __name__ == '__main__':
p=Process(target=task,args=('子进程1',))
p.start()
print(p.pid,) #父进程内查看子类pid的方式
time.sleep(50)
print('父类下查看父类自己的id:',os.getpid())
print('主')

2.join()

import time
from multiprocessing import Process def task(name,n):
print('%s is running'%name)
time.sleep(n)
print('%s is done'%name) if __name__ == '__main__':
p1=Process(target=task,args=("进程1",1)) #用时1s
p2=Process(target=task,args=("进程2",2)) #用时1s
p3=Process(target=task,args=("进程3",3)) #用时1s start_time=time.time()
p1.start()
# p1.join() #如果是这种情况就是总共6s左右了
p2.start()
# p2.join()
p3.start()
# p3.join() # 让父进程在原地等待,等子进程在运行完毕后,才执行下一行代码()
#注意:并不是串行,当第一秒在运行p1时,其实p2、p3也已经在运行,当1s后到p2时只需要再运行1s就到p3了,到p3也是一样。
p1.join()
p2.join()
p3.join()
stop_time=time.time() #3.2848567962646484总结
print(stop_time-start_time)
print('主')

Python开启进程的2中方式的更多相关文章

  1. Python 开启线程的2中方式,线程VS进程(守护线程、互斥锁)

    知识点一: 进程:资源单位 线程:才是CPU的执行单位 进程的运行: 开一个进程就意味着开一个内存空间,存数据用,产生的数据往里面丢 线程的运行: 代码的运行过程就相当于运行了一个线程 辅助理解:一座 ...

  2. [操作系统知识储备,进程相关概念,开启进程的两种方式、 进程Queue介绍]

    [操作系统知识储备,进程相关概念,开启进程的两种方式.进程Queue介绍] 操作系统知识回顾 为什么要有操作系统. 程序员无法把所有的硬件操作细节都了解到,管理这些硬件并且加以优化使用是非常繁琐的工作 ...

  3. Day9 进程理论 开启进程的两种方式 多进程实现并发套接字 join方法 Process对象的其他属性或者方法 守护进程 操作系统介绍

    操作系统简介(转自林海峰老师博客介绍) #一 操作系统的作用: 1:隐藏丑陋复杂的硬件接口,提供良好的抽象接口 2:管理.调度进程,并且将多个进程对硬件的竞争变得有序 #二 多道技术: 1.产生背景: ...

  4. python 开启进程两种方法 multiprocessing模块 介绍

    一 multiprocessing模块介绍 python中的多线程无法利用多核优势,如果想要充分地使用多核CPU的资源(os.cpu\_count\(\)查看),在python中大部分情况需要使用多进 ...

  5. python实现进程的三种方式及其区别

    在python中有三种方式用于实现进程 多进程中, 每个进程中所有数据( 包括全局变量) 都各有拥有⼀份, 互不影响 1.fork()方法 ret = os.fork() if ret == 0: # ...

  6. Python—创建进程的三种方式

    方式一:os.fork() 子进程是从os.fork得到的值,然后赋值开始执行的.即子进程不执行os.fork,从得到的值开始执行. 父进程中fork之前的内容子进程同样会复制,但父子进程空间独立,f ...

  7. python创建进程的两种方式

    1.方式1 import time import multiprocessing def task(arg): time.sleep(2) print(arg) def run(): # 进程1 p1 ...

  8. Python创建进程、线程的两种方式

    代码创建进程和线程的两种方式 """ 定心丸:Python创建进程和线程的方式基本都是一致的,包括其中的调用方法等,学会一个 另一个自然也就会了. "" ...

  9. 并发编程---开启进程方式---查看进程pid

    1.开启进程的两种方式 方式一: from multiprocessing import Process import time def task(name): print('%s is runnin ...

随机推荐

  1. JAVA多线程编程——JAVA内存模型

    一.何为“内存模型” 内存模型描述了程序中各个变量(实例域.静态域和数组元素)之间的关系,以及在实际计算机系统中将变量存储到内存和从内存中取出变量这样的底层细节,对象最终是存储在内存里面的,但是编译器 ...

  2. HTTP 错误 404.15 - Not Found请求筛选模块被配置为拒绝包含的查询字符串过长的请求

    web项目中,get方式传值是通过地址栏中的url参数进行传递的.除了浏览器对url长度的限制大小不一之外,出于安全考虑, IIS中对于URL中参数大小也是有限制的,默认为2048KB. 如果参数大于 ...

  3. VS开发软winform软件的更改用户使用权限

    在使用软件的过程中,我们经常需要使用的软件拥有管理员权限,在开发的过程中,本人就遇到了应为权限不足的问题导致软件不能正常使用的状况. 在此我来记录我遇到的问题. 为开发的软件赋予管理员权限 https ...

  4. 二、antd pro 删除eslint检测

    删除package.json 里 " pre-commit": "npm run lint-staged" 这个对象就可以.

  5. CPP-基础:虚函数表

    虚函数表 对C++ 了解的人都应该知道虚函数(Virtual Function)是通过一张虚函数表(Virtual Table)来实现的.简称为V-Table.在这个表中,主是要一个类的虚函数的地址表 ...

  6. 从输入url到页面加载完成发生了什么详解

    这是一道经典的面试题,这道题没有一个标准的答案,它涉及很多的知识点,面试官会通过这道题了解你对哪一方面的知识比较擅长,然后继续追问看看你的掌握程度.当然我写的这些也只是我的一些简单的理解,从前端的角度 ...

  7. CVE-2011-0065

      环境 备注 操作系统 Windows 7 x86 sp1 专业版 漏洞软件 Firefox 版本号:3.6.16 调试器 Windbg 版本号:6.12.0002.633 0x00 漏洞描述 在F ...

  8. 新手 WordPress主题制作全过程

    WordPress主题制作全过程(一):基础准备 前言: 我想大多数使用WordPress的朋友都喜欢去尝试新的主题,但是换来换去,总是找不到那么一款适合自己的,让人很郁闷.于是很多人萌生了修改现有主 ...

  9. 使用的是html5的canvas将文字转换成图片

    当前功能的运用场景是:用户需要传文件给他人,在用户选择文件之后需要显示一个文件图标和所选文件的名称. 当前代码部分是摘自网上,但是已经忘记在什么地方获取的,如有侵权联系小弟后自当删除. 注意:必须在h ...

  10. mysql中的的按小数位截取

    format()函数返回类型是字符串,满三位会加一个逗号. 针对数字类型转换建议使用 convert或者cast函数,用法如下: format(param, 2) (不建议) convert(para ...