目录:

一、进程

  1. 多任务的概念
  2. 创建子进程----fork【Linux】
  3. 全局变量在多个进程中不共享

  4. 多次fork()
  5. 创建进程----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)----进程的更多相关文章

  1. python学习笔记——守护进程

    1 基本描述 守护进程:是系统中独立的后台服务进程, 特点:独立与终端并且周期性地执行某个任务,其生命周期长,一般随系统启动和终止. 缺点:进程的创建和销毁的时候需要消耗较多的计算机资源. 2 参考 ...

  2. python笔记9 线程进程 threading多线程模块 GIL锁 multiprocessing多进程模块 同步锁Lock 队列queue IO模型

    线程与进程 进程 进程就是一个程序在一个数据集上的一次动态执行过程.进程一般由程序.数据集.进程控制块三部分组成.我们编写的程序用来描述进程要完成哪些功能以及如何完成:数据集则是程序在执行过程中所需要 ...

  3. 20.Python笔记之SqlAlchemy使用

    Date:2016-03-27 Title:20.Python笔记之SqlAlchemy使用 Tags:python Category:Python 作者:刘耀 博客:www.liuyao.me 一. ...

  4. python笔记 - day7

    python笔记 - day7 参考: http://www.cnblogs.com/wupeiqi/articles/5501365.html 面向对象,初级篇: http://www.cnblog ...

  5. python笔记 - day5

    python笔记 - day5 参考: http://www.cnblogs.com/wupeiqi/articles/5484747.html http://www.cnblogs.com/alex ...

  6. python笔记之调用系统命令

    python笔记之调用系统命令 目前我使用到的python中执行cmd的方式有三种 使用os.system("cmd") 该方法在调用完shell脚本后,返回一个16位的二进制数, ...

  7. python笔记之subprocess模块

    python笔记之subprocess模块 [TOC] 从Python 2.4开始,Python引入subprocess模块来管理子进程,以取代一些旧模块的方法:如 os.system.os.spaw ...

  8. guxh的python笔记一:数据类型

    1,基本概念 1.1,数据类型 基本数据类型:字符串,数字,布尔等 引用数据类型:相对不可变(元组),可变(列表,字典,集合等) 基本数据类型存放实际值,引用数据类型存放对象的地址(即引用) ==:判 ...

  9. python笔记-1(import导入、time/datetime/random/os/sys模块)

    python笔记-6(import导入.time/datetime/random/os/sys模块)   一.了解模块导入的基本知识 此部分此处不展开细说import导入,仅写几个点目前的认知即可.其 ...

  10. Python笔记之不可不练

    如果您已经有了一定的Python编程基础,那么本文就是为您的编程能力锦上添花,如果您刚刚开始对Python有一点点兴趣,不怕,Python的重点基础知识已经总结在博文<Python笔记之不可不知 ...

随机推荐

  1. CreateDialog Win32 API调用的一个小问题

    在老版本号的VC编译器上.关键调用是下面2句: InitCommonDialogs(); HWND hwndDialog = CreateDialog(hInstance, "IDD_XXX ...

  2. XMPP 协议工作流程具体解释

    XMPP 要点. 1. client(C) 和server端(S) 通过TCP连接5222port进行全双工通信. 2. XMPP 信息均包括在 XML streams中.一个XMPP会话, 開始于& ...

  3. ubuntu下一款有点感觉的 linux音乐播放器 clementine(小橘子))

    https://www.clementine-player.org/ 在linux听音乐的感觉确实不是很好,音乐播放器很多.但是仅仅只是数量上的优势,在确实不是很好用.自带的rhythmbox确实很占 ...

  4. Android WiFi开发教程(二)——WiFi的搜索和连接

    在上一篇中我们介绍了WiFi热点的创建和关闭,如果你还没阅读过,建议先阅读上一篇文章Android WiFi开发教程(一)——WiFi热点的创建与关闭. 本章节主要继续介绍WiFi的搜索和连接. Wi ...

  5. Codeforces--630A--Again Twenty Five! (水题)

     Again Twenty Five! Time Limit: 500MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u ...

  6. Java中的锁概念

    掌握Java中锁是Java多线程编程中绕不开的知识,只有知道理解Java各种锁才能在编码过程中灵活运用,写出更高效的多线程程序.而理解掌握锁的第一步,可从宏观上对比理解一下各种锁概念. 公平锁/非公平 ...

  7. hdu4405Aeroplane chess(概率与期望dp)

    Aeroplane chess Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  8. Java 最基础的三种排序排序

    主要讲五个排序,冒泡排序.选择排序.插入排序 1)冒泡排序 /** * 冒泡排序 (默认升序排) * 相邻两个相比较,较大的向后放,从数组或者集合中的第一个与第二个比较到倒数第二个与最后一个比较为一轮 ...

  9. alipay.trade.refund (统一收单交易退款接口)[支付宝退款]

    首页官网退款的api: https://doc.open.alipay.com/docs/api.htm?spm=a219a.7395905.0.0.UTBitT&docType=4& ...

  10. Oracle备份Scott

    @echo off echo ================================================ echo Windows环境下Oracle数据库的自动备份脚本 echo ...