Python笔记(29)----进程
目录:
一、进程
- 多任务的概念
- 创建子进程----fork【Linux】
全局变量在多个进程中不共享
- 多次fork()
- 创建进程----multiprocessing【windows】
二、线程
一、进程:
1、多任务概念:多个任务同时进行

(图片来源于https://www.cnblogs.com/wj-1314/p/8263328.html)
- 并发:CPU单核完成多个任务的执行,常用的调度算法:时间片轮转、优先级调度;由于每个任务执行的时间片较短,所以让人觉得多个任务同时在进行。

- 并行:多个CPU完成多个任务的执行。只能在多核CPU上实现,且CPU核数要比任务数量多。

2、创建进程---fork【Linux】
进程VS程序:
程序:编写完毕的代码,在没有运行时称为程序。
进程:正在运行着的代码,即进程。进程除了包含代码还需要运行的环境。
- fork():创建进程
import os
import time ret = os.fork() if ret == 0:
while True:
print("----1----")
time.sleep(1)
else:
while True:
print("----2----")
time.sleep(1)

父进程运行到ret = os.fork()时,产生子进程,父进程ret 得到的值为>0,子进程ret = 0,两者就可以进行并行。操作系统中规定,父进程fork之后产生的ret值是大于0的,子进程ret = 0。
os.getpid():获取当前进程的id。
os.getppid():获取当前进程父进程的id。

3、全局变量在多个进程中不共享
4、多次fork():
第一个fork():红色为父进程,绿色为其产生的子进程。父和子进程打印1和2.
第二个fork():父进程又产生一个子进程,打印11和22。子进程也产生一个子进程,也打印11和22.
故打印一次1和2,两次11和22。

第一次fork():父进程产生一个子进程,两者打印1和2.
第二次fork():父进程又产生一个子进程,打印11和22
故共打印一次1和2,一次11和22

总共产生2^3个进程。

fork()炸弹:以下代码一旦执行,电脑可能会崩掉。

5、创建进程----multiprocessing【windows】
Process实现的进程,主进程会等所有子进程执行完毕之后才关闭;
注意:multiprocessing模块在交互模式是不支持的,故在jupyter下也不执行。
- 包: from multiprocessing import Process
- 创建一个进程:Process()
- Process中的参数:
target = func,表示调用函数,即要创建的进程,
args = [ 要传入func中的参数]
- 与Process相关的常用函数:
start():#让这个进程开始执行func函数里的代码,
p.join(): #堵塞,等待进程结束再执行以下代码
def test(a):
while True:
print(" ----test----")
time.sleep(1)
i = [0,1]
p = Process(target = test,args =(i) ) #创建一个进程,创建test函数对象
p.start() #让这个进程开始执行test函数里的代码
p.join() #堵塞,等待进程结束再执行以下代码
print('----main---')
Python笔记(29)----进程的更多相关文章
- python学习笔记——守护进程
1 基本描述 守护进程:是系统中独立的后台服务进程, 特点:独立与终端并且周期性地执行某个任务,其生命周期长,一般随系统启动和终止. 缺点:进程的创建和销毁的时候需要消耗较多的计算机资源. 2 参考 ...
- python笔记9 线程进程 threading多线程模块 GIL锁 multiprocessing多进程模块 同步锁Lock 队列queue IO模型
线程与进程 进程 进程就是一个程序在一个数据集上的一次动态执行过程.进程一般由程序.数据集.进程控制块三部分组成.我们编写的程序用来描述进程要完成哪些功能以及如何完成:数据集则是程序在执行过程中所需要 ...
- 20.Python笔记之SqlAlchemy使用
Date:2016-03-27 Title:20.Python笔记之SqlAlchemy使用 Tags:python Category:Python 作者:刘耀 博客:www.liuyao.me 一. ...
- python笔记 - day7
python笔记 - day7 参考: http://www.cnblogs.com/wupeiqi/articles/5501365.html 面向对象,初级篇: http://www.cnblog ...
- python笔记 - day5
python笔记 - day5 参考: http://www.cnblogs.com/wupeiqi/articles/5484747.html http://www.cnblogs.com/alex ...
- python笔记之调用系统命令
python笔记之调用系统命令 目前我使用到的python中执行cmd的方式有三种 使用os.system("cmd") 该方法在调用完shell脚本后,返回一个16位的二进制数, ...
- python笔记之subprocess模块
python笔记之subprocess模块 [TOC] 从Python 2.4开始,Python引入subprocess模块来管理子进程,以取代一些旧模块的方法:如 os.system.os.spaw ...
- guxh的python笔记一:数据类型
1,基本概念 1.1,数据类型 基本数据类型:字符串,数字,布尔等 引用数据类型:相对不可变(元组),可变(列表,字典,集合等) 基本数据类型存放实际值,引用数据类型存放对象的地址(即引用) ==:判 ...
- python笔记-1(import导入、time/datetime/random/os/sys模块)
python笔记-6(import导入.time/datetime/random/os/sys模块) 一.了解模块导入的基本知识 此部分此处不展开细说import导入,仅写几个点目前的认知即可.其 ...
- Python笔记之不可不练
如果您已经有了一定的Python编程基础,那么本文就是为您的编程能力锦上添花,如果您刚刚开始对Python有一点点兴趣,不怕,Python的重点基础知识已经总结在博文<Python笔记之不可不知 ...
随机推荐
- Spring MVC-表单(Form)标签-单选按钮(RadioButton)示例(转载实践)
以下内容翻译自:https://www.tutorialspoint.com/springmvc/springmvc_radiobutton.htm 说明:示例基于Spring MVC 4.1.6. ...
- 搭建LVS+Keepalived负载均衡集群
这两天学习了LVS+Keepalived负载均衡的搭建.网上的教程非常多,可是动起手来遇到不少问题. 如今把自己的搭建过程以及遇到的一些问题给分享下. 硬件环境: Macbook 8G内存.250G ...
- 大型项目开发: 隔离 (《大规模C++程序设计》书摘)
书中第六章 隔离. 主要在撰述什么须要定义在头文件?什么应当移到编译单元中? 核心仍然是先区分接口定义与实现细节.实现细节的改变会导致客户代码的又一次编译,从逻辑上也表示与客户代码间可能存在着强耦合. ...
- 自定义列标题 case when
set@schoolid=41;select l.StartTime,l.EndTime,c.EntranceYear as 入学级,cg.Grade as 年级,c.ClassName as 班级名 ...
- 每日总结-05-19(AC自己主动机结束)
今天下午讨论了一下校赛的题,最终最终拍板,把校赛的题目定下来了. 然后今天A掉了4个AC自己主动机的题目.最终完毕了AC自己主动机专辑里面的15个题.至此AC自己主动机全然结束. 明天开启线段树专题. ...
- HDU5195 线段树+拓扑
DZY Loves Topological Sorting Problem Description A topological sort or topological ordering of a di ...
- fixed和absolute
fixed是相对于浏览器窗口固定 absolute是相对于整体网页固定.(整体网页包括所有的内容,包含右侧滑动条滑动所能看到的内容)
- 倒排列表压缩算法汇总——分区Elias-Fano编码貌似是最牛叉的啊!
来看看倒排索引压缩.压缩是拿CPU换IO的最重要手段之一,不论索引是放在硬盘还是内存中.索引压缩的算法有几十种,跟文本压缩不同,索引压缩算法不仅仅需要考虑压缩率,更要考虑压缩和解压性能,否则会解压太慢 ...
- KD树——k=1时就是BST,里面的数学原理还是有不明白的地方,为啥方差划分?
Kd-Tree,即K-dimensional tree,是一棵二叉树,树中存储的是一些K维数据.在一个K维数据集合上构建一棵Kd-Tree代表了对该K维数据集合构成的K维空间的一个划分,即树中的每个结 ...
- iOS版本、iPhone版本、Xcode版本比对
iOS版本 iPhone版本 Xcode版本 其他 2003年 Xcode1.0 2005年4月29日 Xcode2.0 2007年1月9日 iPhone OS(iOS1): 虚拟键盘.谷歌地图 第一 ...