python支持的进程与线程
一、multiprocessing模块介绍
python中的多线程无法利用CPU资源,在python中大部分情况使用多进程。python中提供了非常好的多进程包multiprocessing。
multiprocessing模块用来开启子进程,并在子进程中执行功能(函数),该模块与多线程模块threading的编程接口类似。
multiprocessing的功能众多:支持子进程、通信和共享数据、执行不同形式的同步,提供了Process、Queue、Pipe、Lock等组件。
二、Process类的介绍
1.创建进程的类
- Process([group [, target [, name [, args [, kwargs]]]]]),由该类实例化得到的对象,表示一个子进程中的任务(尚未启动)
- 强调:
- 1. 需要使用关键字的方式来指定参数
- 2. args指定的为传给target函数的位置参数,是一个元组形式,必须有逗号
2.参数介绍

- 1 group参数未使用,值始终为None
- 2
- 3 target表示调用对象,即子进程要执行的任务
- 4
- 5 args表示调用对象的位置参数元组,args=(1,2,'egon',)
- 6
- 7 kwargs表示调用对象的字典,kwargs={'name':'egon','age':18}
- 8
- 9 name为子进程的名称

3.方法介绍

- 1 p.start():启动进程,并调用该子进程中的p.run()
- 2 p.run():进程启动时运行的方法,正是它去调用target指定的函数,我们自定义类的类中一定要实现该方法
- 3
- 4 p.terminate():强制终止进程p,不会进行任何清理操作,如果p创建了子进程,该子进程就成了僵尸进程,使用该方法需要特别小心这种情况。
如果p还保存了一个锁那么也将不会被释放,进而导致死锁- 5 p.is_alive():如果p仍然运行,返回True
- 6
- 7 p.join([timeout]):主线程等待p终止(强调:是主线程处于等的状态,而p是处于运行的状态)。timeout是可选的超时时间,
需要强调的是,p.join只能join住start开启的进程,而不能join住run开启的进程

4.属性介绍

- p.daemon:默认值为False,如果设为True,代表p为后台运行的守护进程,当p的父进程终止时,p也随之终止,并且设定为True后,p不能创建自己的新进程,必须在p.start()之前设置
- p.name:进程的名称
- p.pid:进程的pid
- p.exitcode:进程在运行时为None、如果为–N,表示被信号N结束(了解即可)
- p.authkey:进程的身份验证键,默认是由os.urandom()随机生成的32字符的字符串。这个键的用途是为涉及网络连接的底层进程间通信提供安全性,这类连接只有在具有相同的身份验证键时才能成功(了解即可)

三、Process类的使用
一定要把开进程的代码写在if __name__=='__main__':下面
开一个进程和主进程是并发的关系,我start一下就是先告诉操作系统我要开一个进程
,然而它不会等待,他会去执行下面的代码,完了他吧进程开始后,就开始执行了
strat():方法的功能
1.开启进程
2.执行功能
四、开启进程的两种方式
- from multiprocessing import Process
- 2 import time
- 3 import random
- 4 def piao(name):
- 5 print('%s is piaoing'%name)
- 6 time.sleep(random.randint(1,3))
- 7 print('%s is piao end'%name)
- 8 if __name__ =='__main__':
- 9 p1 = Process(target=piao,kwargs={'name':'alex'})
- 10 p2 = Process(target=piao,kwargs={'name':'alex'})
- 11 p3 = Process(target=piao,kwargs={'name':'alex'})
- 12 p1.start()
- 13 p2.start()
- 14 p3.start()
- 15 print('主进程')
- from multiprocessing import Process
- 2 import time
- 3 import random
- 4 import os
- 5 class Piao(Process):
- 6 def __init__(self,name):
- 7 super().__init__() #必须继承父类的一些属性
- 8 self.name = name
- 9 def run(self): #必须得实现一个run方法
- 10 print(os.getppid(),os.getpid())
- 11 print('%s is piaoing'%self.name)
- 12 time.sleep(random.randint(1,3))
- 13 print('%s is piao end'%self.name)
- 14 if __name__ =='__main__':
- 15 p1 = Piao('alex')
- 16 p2 = Piao('wupeiqi')
- 17 p3 = Piao('yuanhao')
- 18 p1.start()
- 19 p2.start()
- 20 p3.start()
- 21 print('主进程',os.getpid())
getppid()父进程id
getpid() #当前进程id
五、多进程实现套接字并发
- from socket import *
- 2 from multiprocessing import Process
- 3 s = socket(AF_INET,SOCK_STREAM)
- 4 s.setsockopt(SOL_SOCKET,SO_REUSEADDR,1)
- 5 s.bind(('127.0.0.1',8081))
- 6 s.listen(5)
- 7 print('start running...')
- 8 def talk(coon,addr):
- 9 while True:
- 10 try:
- 11 data = coon.recv(1024)
- 12 if not data: break
- 13 coon.send(data.upper())
- 14 except Exception:
- 15 break
- 16 coon.close()
- 17
- 18 if __name__ == '__main__':
- 19 while True:
- 20 coon,addr = s.accept()
- 21 print(coon,addr)
- 22 p =Process(target=talk,args=(coon,addr))
- 23 p.start()
- 24 s.close()
- from socket import *
- 2 c = socket(AF_INET,SOCK_STREAM)
- 3 c.connect(('127.0.0.1',8081))
- 4 while True:
- 5 cmd = input('>>:').strip()
- 6 if not cmd:continue
- 7 c.send(cmd.encode('utf-8'))
- 8 data = c.recv(1024)
- 9 print(data.decode('utf-8'))
- 10 c.close()
python支持的进程与线程的更多相关文章
- python中的进程、线程(threading、multiprocessing、Queue、subprocess)
Python中的进程与线程 学习知识,我们不但要知其然,还是知其所以然.你做到了你就比别人NB. 我们先了解一下什么是进程和线程. 进程与线程的历史 我们都知道计算机是由硬件和软件组成的.硬件中的CP ...
- Python-Cpython解释器支持的进程与线程-Day9
Cpython解释器支持的进程与线程 阅读目录 一 python并发编程之多进程 1.1 multiprocessing模块介绍 1.2 Process类的介绍 1.3 Process类的使用 1.4 ...
- Python学习--17 进程和线程
线程是最小的执行单元,而进程由至少一个线程组成.如何调度进程和线程,完全由操作系统决定,程序自己不能决定什么时候执行,执行多长时间. 进程 fork调用 通过fork()系统调用,就可以生成一个子进程 ...
- Python学习--18 进程和线程
线程是最小的执行单元,而进程由至少一个线程组成.如何调度进程和线程,完全由操作系统决定,程序自己不能决定什么时候执行,执行多长时间. 进程 fork调用 通过fork()系统调用,就可以生成一个子进程 ...
- Cpython解释器支持的进程与线程
一.理论部分 一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): egon在一个时间段内有很多任务要做:python备课的 ...
- python学习之-- 进程 和 线程
python 进程/线程详解 进程定义:以一个整体的形式暴露给操作系统管理,它里面包含对各种资源的调用,内存的管理,网络接口的调用等等,对各种资源管理的集合,就可以叫做一个进程. 线程定义:线程是操作 ...
- Python之路【第十六篇】:Python并发编程|进程、线程
一.进程和线程 进程 假如有两个程序A和B,程序A在执行到一半的过程中,需要读取大量的数据输入(I/O操作), 而此时CPU只能静静地等待任务A读取完数据才能继续执行,这样就白白浪费了CPU资源. 是 ...
- python并发编程-进程池线程池-协程-I/O模型-04
目录 进程池线程池的使用***** 进程池/线程池的创建和提交回调 验证复用池子里的线程或进程 异步回调机制 通过闭包给回调函数添加额外参数(扩展) 协程*** 概念回顾(协程这里再理一下) 如何实现 ...
- python基础之进程、线程、协程篇
一.多任务(多线程) 多线程特点:(1)线程的并发是利用cpu上下文的切换(是并发,不是并行)(2)多线程执行的顺序是无序的(3)多线程共享全局变量(4)线程是继承在进程里的,没有进程就没有线程(5) ...
随机推荐
- HDU_2007
/** *注意:输入的两个数字的大小并不确定 */ #include <iostream> #include <stdio.h> #include <string.h&g ...
- [TabControl] TabControl控件的最佳实践,可以把一个窗体和用户控件添加进来
看下效果吧<ignore_js_op> 下面是一个公共的添加方法看代码 [C#] 纯文本查看 复制代码 ? 01 02 03 04 05 06 07 08 09 10 11 12 13 1 ...
- bootstrap复习
菜单 <div class="row">下拉菜单/分裂菜单</div> <div class="dropdown btn-group&quo ...
- 基于cdn方式的vue+element-ui的单页面架构
一.下载vue2.x,下载element-ui.js以及css 二.html文件 <!DOCTYPE html> <html> <head> <meta ch ...
- OGG复制进程延迟不断增长
1.注意通过进程查找sql_id时,进程号要查询两次 2.杀进程的连接 https://www.cnblogs.com/kerrycode/p/4034231.html 参考资料 1.https:// ...
- [POI2008]Sta(树形dp)
[POI2008]Sta Description 给出一个N个点的树,找出一个点来,以这个点为根的树时,所有点的深度之和最大 Input 给出一个数字N,代表有N个点.N<=1000000 下面 ...
- 获取服务进程server.exe的pid(0号崩溃)
#include "stdafx.h" #include <windows.h> #include <iostream> #include <COMD ...
- lvm分区创建和扩容
shell> fdisk /dev/xvdb #### 选择磁盘 Command (m for help): m #### 帮助 Command action a toggle a bootab ...
- 记录ViewPager配合Fragment使用中遇到的一个问题
java.lang.IllegalStateException: FragmentManager is already executing transactions 如图所示: 当调用 notifyD ...
- 026:if标签使用详解
if标签使用详解: if 标签: if 标签相当于 Python 中的 if 语句,有 elif 和 else 相对应,但是所有的标签都需要用标签符号 {% %} 进行包裹. if 标签中可以使 ...