使用Condition对象可以在某些事件触发或者达到特定的条件后才处理数据,Condition除了具有Lock对象的acquire方法和release方法外,

还有wait方法,notify方法,notifyAll方法等用于条件处理。

条件变量保持线程同步:threading.Condition()

wait():线程挂起,直到收到一个notify通知才会被唤醒继续运行

notify():通知其他线程,那些挂起的线程接到这个通知之后会开始运行

notifyAll(): 如果wait状态线程比较多,notifyAll的作用就是通知所有线程(这个一般用得少)

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

PS:有朋友说看了我日志里面的代码也看了注释,但是还是不懂,那今天来个简单的,

用一对屌丝(空白哥和西米哥)的对话来诠释代码(生产者-消费者)原图:

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#coding:utf-8
import threading
import time
cond = threading.Condition()
class kongbaige(threading.Thread):
    def __init__(self,
cond, diaosiname):
        threading.Thread.__init__(self,
name 
= diaosiname)
        self.cond = cond
           
    def run(self):
        self.cond.acquire() #获取锁
           
        print self.getName() + ':一支穿云箭'  #空白哥说的第一句话
        self.cond.notify()                   #唤醒其他wait状态的线程(通知西米哥
让他说话)
        #然后进入wait线程挂起状态等待notify通知(等西米哥的回复,接下来俩人就开始扯蛋)
        self.cond.wait()
           
        print self.getName() + ':山无棱,天地合,乃敢与君绝!'
        self.cond.notify()
        self.cond.wait()
           
        print self.getName() + ':紫薇!!!!(此处图片省略)'
        self.cond.notify()
        self.cond.wait()
           
        print self.getName() + ':是你'
        self.cond.notify()
        self.cond.wait()
           
        #这里是空白哥说的最后一段话,接下来就没有对白了
        print self.getName() + ':有钱吗
借点'
        self.cond.notify()             #通知西米哥
        self.cond.release()            #释放锁
           
           
           
class ximige(threading.Thread):
    def __init__(self,
cond, diaosiname):
        threading.Thread.__init__(self,
name 
= diaosiname)
        self.cond = cond
           
    def run(self):
        self.cond.acquire()
        self.cond.wait()   #线程挂起(等西米哥的notify通知)
           
        print self.getName() +':千军万马来相见'
        self.cond.notify()  #说完话了notify空白哥wait的线程
        self.cond.wait()    #线程挂起等待空白哥的notify通知
           
        print self.getName() + ':海可枯,石可烂,激情永不散!'
        self.cond.notify()
        self.cond.wait()
           
        print self.getName() + ':尔康!!!(此处图片省略)'
        self.cond.notify()
        self.cond.wait()
           
        print self.getName() + ':是我'
        self.cond.notify()
        self.cond.wait()
           
        #这里是最后一段话,后面空白哥没接话了
所以说完就释放锁 结束线程
        print self.getName() + ':滚' 
        self.cond.release()
           
           
kongbai = kongbaige(cond, '   
'
)
ximi = ximige(cond, '西米')
#尼玛下面这2个启动标志是关键,虽然是空白哥先开的口,但是不能让他先启动,
#因为他先启动的可能直到发完notify通知了,西米哥才开始启动,
#西米哥启动后会一直处于44行的wait状态,因为空白哥已经发完notify通知了进入wait状态了,
#而西米哥没收到
#造成的结果就是2根线程就一直在那挂起,什么都不干,也不扯蛋了
ximi.start()
kongbai.start()
######运行结果######
    :一支穿云箭
西米:千军万马来相见
    :山无棱,天地合,乃敢与君绝!
西米:海可枯,石可烂,激情永不散!
    :紫薇!!!!(此处图片省略)
西米:尔康!!!(此处图片省略)
    :是你
西米:是我
    :有钱吗
借点
西米:滚

转自:http://zeping.blog.51cto.com/6140112/1258977

python多线程--theading模块的更多相关文章

  1. 再看python多线程------threading模块

    现在把关于多线程的能想到的需要注意的点记录一下: 关于threading模块: 1.关于 传参问题 如果调用的子线程函数需要传参,要在参数后面加一个“,”否则会抛参数异常的错误. 如下: for i ...

  2. Python(多线程threading模块)

    day27 参考:http://www.cnblogs.com/yuanchenqi/articles/5733873.html CPU像一本书,你不阅读的时候,你室友马上阅读,你准备阅读的时候,你室 ...

  3. Python中Queue模块及多线程使用

    Python的Queue模块提供一种适用于多线程编程的FIFO实现.它可用于在生产者(producer)和消费者(consumer)之间线程安全(thread-safe)地传递消息或其它数据,因此多个 ...

  4. python的_thread模块来实现多线程(<python核心编程例子>)

    python中_thread模块是一个低级别的多线程模块,它的问题在于主线程运行完毕后,会立马把子线程给结束掉,不加处理地使用_thread模块是不合适的.这里把书中讲述的有关_thread使用的例子 ...

  5. python 多线程,tthread模块比较底层,而threading模块是对thread做了一些包装,multithreading

    Python多线程详解 2016/05/10 · 基础知识 · 1 评论· 多线程 分享到:20 本文作者: 伯乐在线 - 王海波 .未经作者许可,禁止转载!欢迎加入伯乐在线 专栏作者. 1.多线程的 ...

  6. python多线程与threading模块

    python多线程与_thread模块 中介绍了线程的基本概念以及_thread模块的简单示例.然而,_thread模块过于简单,使得我们无法用它来准确地控制线程,本文介绍threading模块,它提 ...

  7. python多线程与_thread模块

    进程与线程 1.进程:计算机程序只是存储在磁盘中的可执行二进制(或其他类型)的文件.只有把他们加载到内存中并被操作系统调用,才具有其生命周期.进程则是一个执行中的程序.每个进程都拥有自己的地址空间,内 ...

  8. python多线程学习记录

    1.多线程的创建 import threading t = t.theading.Thread(target, args--) t.SetDeamon(True)//设置为守护进程 t.start() ...

  9. Python多线程多进程

    一.线程&进程 对于操作系统来说,一个任务就是一个进程(Process),比如打开一个浏览器就是启动一个浏览器进程,打开一个记事本就启动了一个记事本进程,打开两个记事本就启动了两个记事本进程, ...

随机推荐

  1. ACdream 1007

    input T           <=10 n k            n<=1000         k<=10^18 a1,a2,...an                | ...

  2. Android 发送HTTP GET POST 请求以及通过 MultipartEntityBuilder 上传文件(二)

    Android 发送HTTP GET POST 请求以及通过 MultipartEntityBuilder 上传文件第二版 上次粗略的写了相同功能的代码,这次整理修复了之前的一些BUG,结构也大量修改 ...

  3. hdu 3986 Harry Potter and the Final Battle

    一个水题WA了60发,数组没开大,这OJ也不提示RE,光提示WA...... 思路:先求出最短路,如果删除的边不是最短路上的,那么对结果没有影响,要有影响,只能删除最短路上的边.所以枚举一下最短路上的 ...

  4. noip2015Day2T1-跳石头

    题目描述 Description 一年一度的“跳石头”比赛又要开始了! 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之间,有N ...

  5. SVD分解技术数学解释

    SVD分解 SVD分解是LSA的数学基础,本文是我的LSA学习笔记的一部分,之所以单独拿出来,是因为SVD可以说是LSA的基础,要理解LSA必须了解SVD,因此将LSA笔记的SVD一节单独作为一篇文章 ...

  6. nginx: [emerg] socket() [::]:80 failed (97: Address family not supported by protocol)

    环境:Centos6.5 行为:安装nginx 问题: nginx: [emerg] socket() [::]: failed (: Address family not supported by ...

  7. Node.js:服务器与数据流

    1.Node 常被用来构建服务器,下面代码就是创建了一个服务器. var http = require('http'); var server = http.createServer(); serve ...

  8. CSS3秘笈复习:第一章&第二章&第三章

    第一章: 1.<cite>标签不仅可以将网页设置为斜体,还能给标题做上标记,使它便于被搜索引擎搜索到. 第二章: 1.import指令链接样式表: CSS本身有一种添加外部样式的方法:@i ...

  9. javascript apply()和call()

    原文链接 http://www.jb51.net/article/30883.htm 想要理解透彻apply()和call() ,还要需要理解this  作用域 局部变量  全局变量 js apply ...

  10. hdu_5903_Square Distance(dp)

    题目链接:hdu_5903_Square Distance 题意: 给你一个长度为n的a串,一个数m,现在让你构造一个长度也为n的b串,使这个串是由两个相同的串拼起来的,并且和a串对应的位不同的数量为 ...