python生产者消费者模型

时间:2022-09-09 19:01:26

业界用的比较广泛,多线程之间进行同步数据的方法,解决线程之间堵塞,互相不影响。

server --> 生产者

client --> 消费者

在一个程序中实现又有生产者又有消费者

,生产者不断生产,消费者不断消费,达到并行数据安全完整交互的目的。

所以会有消息队列的关键字产生,队列是典型的生产者消费者模型

例如:吃包子例子,生产慢,消费快

#!/usr/bin/env python
#-*- coding:utf-8 -*-

import threading, time
import Queue
import random
q = Queue.Queue() #模拟生产带,如果有瓶颈可以增加q(生产带)来提高效率

def Producer(name):
  for i in range(20):
    q.put(i) #往生产带放东西,是随机放置的
    print '\033[32;1mProducer %s has made %s baozi ...\033[0m'% (name,i)
    time.sleep(random.randrange(2)) #假设放置的速度是1s随机放置一次

def Consumer(name): #模拟消费者
  count = 0
  while count < 20:
    data = q.get() #消费者从生产带拿东西
    print '\033[31;1mConsumer %s has eaten %s baozi ...\033[0m' %(name,data)
    count +=1
    time.sleep(random.randrange(4)) #消费者要比生产者快,所以时间上假设是1-2s随机消费一次

p = threading.Thread(target=Producer,args=('Joson',))
c = threading.Thread(target=Consumer,args=('Li',))
p.start()
c.start()

python生产者消费者模型的更多相关文章

  1. python生产者消费者模型优点

    生产者消费者模型:解耦,通过队列降低耦合,支持并发,生产者和消费者是两个独立的并发体,他们之间使用缓存区作为桥梁连接,生产者指望里丢数据,就可以生产下一个数据了,消费者从中拿数据,这样就不会阻塞,影响 ...

  2. 操作系统OS,Python - 生产者消费者模型

    1. 缓冲区(此处用阻塞队列充当),解决消费者和生产者强耦合问题.(生产者和消费者不直接通信) 2. 通过平衡生产者线程和消费者线程,来提高程序整体处理数据速度. 3. 在并发编程中该模式能解决大多数 ...

  3. python 生产者消费者模型

    import time def consumer(name): print("%s开始吃包子了"%name) while True: ret = yield time.sleep( ...

  4. Python学习笔记——进阶篇【第九周】———线程、进程、协程篇(队列Queue和生产者消费者模型)

    Python之路,进程.线程.协程篇 本节内容 进程.与线程区别 cpu运行原理 python GIL全局解释器锁 线程 语法 join 线程锁之Lock\Rlock\信号量 将线程变为守护进程 Ev ...

  5. 进程,线程,GIL,Python多线程,生产者消费者模型都是什么鬼

    1. 操作系统基本知识,进程,线程 CPU是计算机的核心,承担了所有的计算任务: 操作系统是计算机的管理者,它负责任务的调度.资源的分配和管理,统领整个计算机硬件:那么操作系统是如何进行任务调度的呢? ...

  6. python并发编程之多进程&lpar;二&rpar;:互斥锁(同步锁)&amp&semi;进程其他属性&amp&semi;进程间通信(queue)&amp&semi;生产者消费者模型

    一,互斥锁,同步锁 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 竞争带来的结果就是错乱,如何控制,就是加锁处理 part1:多个进程共享同一打印终 ...

  7. Python之路&lpar;第三十八篇&rpar; 并发编程:进程同步锁&sol;互斥锁、信号量、事件、队列、生产者消费者模型

    一.进程锁(同步锁/互斥锁) 进程之间数据不共享,但是共享同一套文件系统,所以访问同一个文件,或同一个打印终端,是没有问题的, 而共享带来的是竞争,竞争带来的结果就是错乱,如何控制,就是加锁处理. 例 ...

  8. python 全栈开发,Day39&lpar;进程同步控制&lpar;锁&comma;信号量&comma;事件&rpar;&comma;进程间通信&lpar;队列&comma;生产者消费者模型&rpar;&rpar;

    昨日内容回顾 python中启动子进程并发编程并发 :多段程序看起来是同时运行的ftp 网盘不支持并发socketserver 多进程 并发异步 两个进程 分别做不同的事情 创建新进程join :阻塞 ...

  9. python网络编程--进程&lpar;方法和通信&rpar;&comma;锁&comma; 队列&comma;生产者消费者模型

    1.进程 正在进行的一个过程或者说一个任务.负责执行任务的是cpu 进程(Process: 是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在 ...

随机推荐

  1. C&num;语法知识

    接口: 接口可以包含方法.属性.事件.索引器或这四种成员类型的任意组合. 接口不能包含常量.字段.运算符.实例构造函数.析构函数或类型.当类或结构实现接口时,类或结构必须为该接口定义的所有成员提供实现 ...

  2. PHP 标准库 SPL 之数据结构栈(SplStack)简单实践

    PHP 5.3.0 版本及以上的堆栈描述可以使用标准库 SPL 中的 SplStack class,SplStack 类继承双链表 ( SplDoublyLinkedList ) 实现栈. 代码: & ...

  3. nginx下禁止访问robots&period;txt的设置方法

    关于robots.txt文件:搜索引擎通过一种程序robot(又称spider),自动访问互联网上的网页并获取网页信 息.您可以在您的网站中创建一个纯文本文件robots.txt,在这个文件中声明该网 ...

  4. libpcap文件格式分析

    第一部分:PCAP包文件格式 一 基本格式: 文件头 数据包头数据报数据包头数据报...... 二.文件头: 文件头结构体  sturct pcap_file_header  {       DWOR ...

  5. Node&period;js 基础介绍

    什么是Node.js 官网介绍: Node.js® is a JavaScript runtime built on Chrome's V8 JavaScript engine. Node.js us ...

  6. Sqlserver UrlEncode

    Sqlserver  UrlEncode if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[UrlEncode ...

  7. GNum试用体验

    只需在GNum上注册一个用户名,填上自己的电话号码,它就会自动生成一个URL,你的朋友(可以不注册GNum)在浏览器上进入这个 URL,就可以给你的手机打电话,目前可以免费通话200分钟,而且如果你邀 ...

  8. 洛谷P4197 Peaks&amp&semi;&amp&semi;克鲁斯卡尔重构树学习笔记(克鲁斯卡尔重构树&plus;主席树)

    传送门 据说离线做法是主席树上树+启发式合并(然而我并不会) 据说bzoj上有强制在线版本只能用克鲁斯卡尔重构树,那就好好讲一下好了 这里先感谢LadyLex大佬的博客->这里 克鲁斯卡尔重构树 ...

  9. SQLServer跨服务器访问数据库&lpar;openrowset&sol;opendatasource&sol;openquery&rpar;

    SQLServer跨服务器访问数据库(openrowset/opendatasource/openquery) 1.启用Ad Hoc Distributed Queries 在使用openrowset ...

  10. 【&lbrack;ZJOI2008&rsqb;泡泡堂】

    想贪心就是反复\(hack\)自己的过程 首先这很田忌赛马,但是又不完全一样 田忌赛马保证了所有马的实力不同,因此没有平局 田忌赛马的策略是当自己最强的马比不过对方最强的马的时候,就用自己最弱的马来自 ...