一、进程

          我们电脑的应用程序,都是进程,进程是资源分配的单位。进程切换需要的资源最大,效率低。
        进程之间相互独立
        cpu密集的时候适合用多进程

#多进程并发

  1. import multiprocessing
  2. from multiprocessing import Pool
  3. import time
  4. def test1():
  5. for i in range(10):
  6. time.sleep(1)
  7. print('test', i)
  8.  
  9. def test2():
  10. for i in range(10):
  11. time.sleep(1)
  12. print('test', i)
  13.  
  14. if __name__ == '__main__':
  15. p1 = multiprocessing.Process(target=test1)
  16. p2 = multiprocessing.Process(target=test2)
  17. p1.start()
  18. p2.start()

#进程之间不共享

  1. import multiprocessing
  2. from multiprocessing import Pool
  3. import time
  4. import threading
  5. g_num = 0
  6. def test1():
  7. global g_num
  8. for i in range(10):
  9. g_num += 1
  10. def test2():
  11. print(g_num)
  12. if __name__ == '__main__':
  13. p1 = multiprocessing.Process(target=test1)
  14. p2 = multiprocessing.Process(target=test2)
  15. p1.start()
  16. p1.join()
  17. p2.start()
结果是 0 
 

二、进程池

        python中,进程池内部会维护一个进程序列,当需要时,程序会去进程池中获取一个进程,如果进程池序列中没有可供使用的进程,那么程序就会等待,直到进程池中有可用的进程为止。

#进程池实现并发

  1. import multiprocessing
  2. from multiprocessing import Pool
  3. import time
  4. import threading
  5. g_num = 0
  6. def test1():
  7. for i in range(10):
  8. time.sleep(1)
  9. print('test1',i)
  10. def test2():
  11. for i in range(10):
  12. time.sleep(1)
  13. print('test2',i)
  14.  
  15. if __name__ == '__main__':
  16. pool = Pool(2) # 允许进程池里同时放入2个进程 其他多余的进程处于挂起状态
  17. pool.apply_async(test1)
  18. pool.apply_async(test2)
  19. pool.close() # close() 必须在join()前被调用
  20. pool.join() # 进程池中进程执行完毕后再关闭,如果注释,那么程序直接关闭。

  21. join() 方法实现进程间的同步,等待所有进程退出。
  22. close() 用来阻止多余的进程涌入进程池 Pool 造成进程阻塞。
  23. apply_async()本身就可以返回被进程调用的函 数的返回值 

三、 协程:

        协程相对独立,有自己的上下文,但其切换由自己控制,由当前协程切换到其他协程由协程来控制。而线程的切换由系统控制。  协程切换需要的资源很小,效率高
  多进程、多线程根据cpu核数不一样可能是并行的,但是协程在一个线程中

#协程,自动切换(可以在test2sleep的时候切换去执行test1)

  1. import gevent,time
  2. from gevent import monkey
  3. monkey.patch_all() #gevent三行放在其他所有import语句之前可以避免出现警告或者报错信息,导致程序不能正常运行
  4. def test1():
  5. for i in range(10):
  6. time.sleep(1)
  7. print('test1',1)
  8.  
  9. def test2():
  10. for i in range(10):
  11. time.sleep(2)
  12. print('test2',2)
  13. g1 = gevent.spawn(test1)
  14. g2 = gevent.spawn(test2)
  15. g1.join()
  16. g2.join()
 

python3多进程 进程池 协程并发的更多相关文章

  1. python GIL全局解释器锁,多线程多进程效率比较,进程池,协程,TCP服务端实现协程

    GIL全局解释器锁 ''' python解释器: - Cpython C语言 - Jpython java ... 1.GIL: 全局解释器锁 - 翻译: 在同一个进程下开启的多线程,同一时刻只能有一 ...

  2. 多道技术 进程 线程 协程 GIL锁 同步异步 高并发的解决方案 生产者消费者模型

    本文基本内容 多道技术 进程 线程 协程 并发 多线程 多进程 线程池 进程池 GIL锁 互斥锁 网络IO 同步 异步等 实现高并发的几种方式 协程:单线程实现并发 一 多道技术 产生背景 所有程序串 ...

  3. python运维开发(十一)----线程、进程、协程

    内容目录: 线程 基本使用 线程锁 自定义线程池 进程 基本使用 进程锁 进程数据共享 进程池 协程 线程 线程使用的两种方式,一种为我们直接调用thread模块上的方法,另一种我们自定义方式 方式一 ...

  4. Python进阶----异步同步,阻塞非阻塞,线程池(进程池)的异步+回调机制实行并发, 线程队列(Queue, LifoQueue,PriorityQueue), 事件Event,线程的三个状态(就绪,挂起,运行) ,***协程概念,yield模拟并发(有缺陷),Greenlet模块(手动切换),Gevent(协程并发)

    Python进阶----异步同步,阻塞非阻塞,线程池(进程池)的异步+回调机制实行并发, 线程队列(Queue, LifoQueue,PriorityQueue), 事件Event,线程的三个状态(就 ...

  5. windows下多进程加协程并发模式

    好久没更新博客了.正好最近要整理一下最近这段时间做过的项目以及学习python的一些心得.如标题所示,今天就来说说windows下多进程加协程并发模式.其实网上还是蛮多在linux下的多进程加协程并发 ...

  6. python3通过gevent.pool限制协程并发数量

    协程虽然是轻量级的线程,但到达一定数量后,仍然会造成服务器崩溃出错.最好的方法通过限制协程并发数量来解决此类问题. server代码: #!/usr/bin/env python # -*- codi ...

  7. Python并发编程系列之常用概念剖析:并行 串行 并发 同步 异步 阻塞 非阻塞 进程 线程 协程

    1 引言 并发.并行.串行.同步.异步.阻塞.非阻塞.进程.线程.协程是并发编程中的常见概念,相似却也有却不尽相同,令人头痛,这一篇博文中我们来区分一下这些概念. 2 并发与并行 在解释并发与并行之前 ...

  8. python并发编程之Queue线程、进程、协程通信(五)

    单线程.多线程之间.进程之间.协程之间很多时候需要协同完成工作,这个时候它们需要进行通讯.或者说为了解耦,普遍采用Queue,生产消费模式. 系列文章 python并发编程之threading线程(一 ...

  9. Python之线程、进程和协程

    python之线程.进程和协程 目录: 引言 一.线程 1.1 普通的多线程 1.2 自定义线程类 1.3 线程锁 1.3.1 未使用锁 1.3.2 普通锁Lock和RLock 1.3.3 信号量(S ...

随机推荐

  1. kubernetes环境搭建 -k8s笔记(一)

    一.环境准备 1.硬件及版本信息: cpu&内存:2核心,2G 网络: 每台vm主机2块网卡,一块NAT用于上网,别一块配置成 "仅主机模式",网段为192.168.100 ...

  2. 使用NPOI读取Word文档内容并进行修改

    前言 网上使用NPOI读取Word文件的例子现在也不少,本文就是参考网上大神们的例子进行修改以适应自己需求的. 参考博文 http://www.cnblogs.com/mahongbiao/p/376 ...

  3. 手把手教你搭饥荒专用服务器(三)—MOD及其他高级设置

    友情链接: 手把手教你搭饥荒专用服务器(一)-服务器准备工作 手把手教你搭饥荒专用服务器(二)-环境配置及基本使用 手把手教你搭饥荒专用服务器(三)-MOD及其他高级设置 手把手教你搭饥荒专用服务器( ...

  4. Xtrabackup备份与恢复

    一.Xtrabackup介绍 MySQL冷备.mysqldump.MySQL热拷贝都无法实现对数据库进行增量备份.在实际生产环境中增量备份是非常实用的,如果数据大于50G或100G,存储空间足够的情况 ...

  5. 推荐系统中的nlp知识

    都是转自其他博客,好好学习! 概述: https://blog.csdn.net/starzhou/article/details/73930117 tf-idf https://blog.csdn. ...

  6. react项目中登陆注册验证码的倒计时,页面刷新不会重置

    目前很多的网站和app在做登陆注册时都会用到手机验证码,为了防止验证码轰炸,也就是随意的点击验证码,一般我们需要对获取验证码进行一些限制,最常用到的是在规定时间内不得重复发送. 实现倒计时很简单,可以 ...

  7. ATM管理系统

    一.题目要求 编写一个ATM管理系统,语言不限,要求应包括以下主要功能: (1)开户,销户 (2)查询账户余额 (3)存款 (4)取款 (5)转账(一个账户转到另一个账户)等 二.代码提交 开户 pu ...

  8. Spring Cloud是什么鬼?

    研究了一段时间Spring Boot了准备向Spring Cloud进发,公司架构和项目也全面拥抱了Spring Cloud.在使用了一段时间后发现Spring Cloud从技术架构上降低了对大型系统 ...

  9. 【函数分享】每日PHP函数分享(2021-1-9)

    implode() 将一个一维数组的值转化为字符串. string implode ( string $glue , array $pieces ) 参数描述 glue     默认为空的字符串. p ...

  10. CSS卡片旋转

    html{ perspective: 800px; } body{ display:flex; flex-wrap: wrap; } .card{ transform-style: preserve- ...