python process
原文:https://www.cnblogs.com/LY-C/p/9145729.html
进程:资源分配的基本单位,进程数量为cpu核数+1,os.cpu_count()。计算密集时,使用进程
守护进程随着主进程的最后一句代码结束而结束
使用process模块可以创建进程
from multiprocessing import Process
p = Process(target,args,name)
target:表示调用对象,即子进程要执行的任务
args:表示调用对象的位置参数”元组“
name:进程的名字
方法
p.start():启动一个子进程,系统决定什么时候调用p.run()
p.run():立即运行子进程
p.terminate():强制终止进程p,不会进行任何清理操作,如果p创建了子进程,该子进程就成了僵尸进程,使用该方法需要特别小心这种情况。如果p还保存了一个锁那么也将不会被释放,进而导致死锁
p.is_alive():判断p进程是否还存在,如果p仍然运行,返回True
p.join([timeout]):异步变同步,让主进程等待子进程执行完毕(强调:是主线程处于等的状态,而p是处于运行的状态)。timeout是可选的超时时间,需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程
多进程启动
#如果好多进程都要启动,代码太长可以写成这样
p_list = [p1,p2,p3,p4,p5]
[i.start() for i in p_list]
属性
p.daemon:默认值为False,如果设为True,代表p为后台运行的守护进程,当p的父进程终止时,p也随之终止,并且设定为True后,p不能创建自己的新进程,必须在p.start()之前设置
p.name:进程的名称
p.pid:进程的pid
示例
from multiprocessing import Process
import time def func(name):
print('son 的名字是 %s '%name)
time.sleep(5)
print('这里是son') if __name__ == '__main__':
p = Process(target = func,args=('xxx',))
p.start()
time.sleep(2)
p.join()# 代码执行到这里,主进程main会停止等待子进程执行完毕才继续
print('这里是father')
锁机制
from multiprocessing import Lock
l = Lock() #创建一个锁 l.acquire() # 加锁 l.release() # 释放锁
信号机制
from multiprocessing import Semaphore
l = Semaphore(n) #创建锁,n是指初始化一把锁配几把钥匙,一个int型 l.acquire() #加锁,可以加n把锁 l.release() #释放锁 #信号量机制比锁机制多了一个计数器,这个计数器是用来记录当前剩余几把钥匙的。
#当计数器为0时,表示没有钥匙了,此时acquire()处于阻塞。
#对于计数器来说,每acquire一次,计数器内部就减1,release一次,计数器就加1
事件机制
from multiprocessing import Event e = Event() #创建事件
e.wait() #判断is_set的bool值,如果bool为True,则非阻塞,bool值为False,则阻塞
e.set() #将is_set()设为True
e.clear() # 将is_set()设为False e.is_set() # 标识
# 事件是通过is_set()的bool值,去标识e.wait() 的阻塞状态
# 当is_set()的bool值为False时,e.wait()是阻塞状态
# 当is_set()的bool值为True时,e.wait()是非阻塞状态
# 当使用set()时,是把is_set的bool变为True
# 当使用clear()时,是把is_set的bool变为False
队列
#先进先出
from multiprocessing import Queue q = Queue([n]) #n为该队列最多元素的个数,省略不限制 q.get( [ block [ ,timeout ] ] )
#返回q中的一个项目。如果q为空,此方法将阻塞,直到队列中有项目可用为止。
#block用于控制阻塞行为,默认为True. 如果设置为False,将引发Queue.Empty异常#timeout是可选超时时间,用在阻塞模式中。如果在指定的时间间隔内没有项目可用,将引发Queue.Empty异常。 q.get_nowait( ) #同q.get(False)方法。 q.put(item [, block [,timeout ] ] )
#将item放入队列。如果队列已满,此方法将阻塞至有空间可用为止。
#block控制阻塞行为,默认为True。如果设置为False,将引发Queue.Empty异常#timeout指定在阻塞模式中等待可用空间的时间长短。超时后将引发Queue.Full异常。 q.qsize() #返回队列中目前项目的正确数量。
q.empty() #如果调用此方法时 q为空,返回True。
q.full() #如果队列已满,返回为True.
进程间共享内存
from multiprocessing import Manager
m = Manager()
num = m.dict({键 : 值})
num = m.list([1,2,3])
进程池
from multiprocessing import Pool
p = Pool(5) #创建进程池,限定进程个数 p.apply(func,args=(,)) #同步执行线程,阻塞 p.apply_async(func,args=(,),callback=func2) #异步执行线程,非阻塞
#func函数返回的值,传给了callback后面接的函数,进一步执行 p.map(func,iter) #异步执行,iter为可迭代对象 p.close() #不在向进程池中添加任务,同步不需要使用 p.join() #等待进程池执行完任务,同步不需要使用
python process的更多相关文章
- python process,queue
#-*- coding:utf-8 -*- from multiprocessing import Process,Queue import os,time,random def write(q): ...
- Python process (进程)
进程 (process) 进程是对各种资源管理的集合,包含对各种资源的调用.内存的管理.网络接口的调用 进程要操作 CPU 必须先启动一个线程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程 ...
- 会务准备期间材料准备工作具体实施总结 ----(vim技巧应用, python信息提取与整合, microsoft word格式调整批量化)
会务准备期间材料准备工作具体实施总结(vim, python, microsoft word) span.kw { color: #007020; font-weight: bold; } code ...
- python执行shell命令
1 os.system 可以返回运行shell命令状态,同时会在终端输出运行结果 例如 ipython中运行如下命令,返回运行状态status os.system('cat /etc/passwdqc ...
- [转载] python利用psutil遍历进程名字和exe所在目录
本文转载自: http://www.duanzhihe.com/1594.html http://www.jianshu.com/p/64e265f663f6 import psutil,os,tim ...
- 用gdb调试python多线程代码-记一次死锁的发现
| 版权:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.如有问题,可以邮件:wangxu198709@gmail.com 前言 相信很多人都有 ...
- python并发编程之多进程(二):互斥锁(同步锁)&进程其他属性&进程间通信(queue)&生产者消费者模型
一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...
- python threading模块中的join()方法和setDeamon()方法的一些理解
之前用多线程的时候看见了很多文章,比较常用的大概就是join()和setDeamon()了. 先说一下自己对join()的理解吧: def join(self, timeout=None): &quo ...
- python模块:subprocess
# subprocess - Subprocesses with accessible I/O streams # # For more information about this module, ...
随机推荐
- NLP(二十) 利用词向量实现高维词在二维空间的可视化
准备 Alice in Wonderland数据集可用于单词抽取,结合稠密网络可实现其单词的可视化,这与编码器-解码器架构类似. 代码 from __future__ import print_fun ...
- vue.js如何根据后台返回来的图片url进行图片下载
最近在做一个前端vue.js对接的功能模块时,需要实现一个下载图片的功能,后台返回来的是一串图片url,试了很多种方法,发现点击下载时出来的效果都是跳着到一个新的图片网页,后来经过一番琢磨,终于解决了 ...
- 洛谷 P1070 道路游戏 DP
P1070 道路游戏 题意: 有一个环,环上有n个工厂,每个工厂可以生产价格为x的零钱收割机器人,每个机器人在购买后可以沿着环最多走p条边,一秒走一条,每条边不同时间上出现的金币是不同的,问如何安排购 ...
- AOJ-2249-Road Construction-dijkstra-最小花费
Road Construction 题意:在一个无向图中,每条边上有建设的花费和路径的长度,要求求得,在保持每个点到1号点最小距离不变的情况下,求最小的总花费: 思路:用dijkstra 找出每个点的 ...
- 【赛后总结+部分题解】2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛
赛后总结: T:今天状态一般,甚至有点疲惫.然后12点比赛开始,和队友开始看题,从最后往前面看,发现数学题公式看不懂.然后发现队友已经双开做1001和1006了,我看着1007有人A,开始做1007. ...
- CodeForces 474F Ant colony ST+二分
Ant colony 题解: 因为一个数是合法数,那么询问区间内的其他数都要是这个数的倍数,也就是这个区间内的gcd刚好是这个数. 对于这个区间的gcd来说,不能通过前后缀来算. 所以通过ST表来询问 ...
- 文档打印 js print调用打印dom内容
1.首先按目前研究 print可以打印dom 2.被设置overflow:hidden 的模块,打印时会被截掉. 3.被设置成 display:none 的dom 打印不会有样式 边框等. 4.如果需 ...
- Git使用(二)版本库创建及文件修改
一.创建版本库 1.安装完成后,在开始菜单里找到“Git”->“Git Bash”,蹦出一个类似命令行窗口的东西,就说明Git安装成功! 安装完成后,还需要最后一步设置,在命令行输入: $ gi ...
- Vert.x 学习之MongoDB Client
Vert.x MongoDB Client 原文档:Vert.x MongoDB Client 组件介绍 您的 Vert.x 应用可以使用 Vert.x MongoDB Client(以下简称客户端) ...
- Navicate for mysql如何导入一个sql文件
我在做的项目是宜立方商城的项目,现在需要把见表的sql文件导入到navicate中去,步骤如下: ①新建一个数据库,如下: ②在数据库名字上右键,选择运行sql文件 ③选择如下sql文件 ④刷新之后: