#练习:线程等待 Event e.set() e.wait()
 
from threading import Thread, Lock
import threading
import time
 
def wait_for_event(e):
    #Wait for the event to be set before doing anything
    print 'wait_for_event: starting'
    e.wait() # 等待收到能执行信号,如果一直未收到将一直阻塞
    print 'wait_for_event: e.is_set()->', e.is_set()
 
def wait_for_event_timeout(e, t):
    #Wait t seconds and then timeout
    print 'wait_for_event_timeout: starting'
    e.wait(t)# 等待t秒超时,此时Event的状态仍未未设置
    print 'wait_for_event_timeout: e.is_set()->', e.is_set()
    e.set()# 设置Event的状态
 
if __name__ == '__main__':
    e = threading.Event()
    print "begin, e.is_set()", e.is_set()
    w1 = Thread(name = 'block', target = wait_for_event, args = (e,))
    w1.start()
 
    w2 = Thread(name = 'nonblock', target = wait_for_event_timeout, args = (e, 2))
    w2.start()
    print 'main: waiting before calling Event.set()'
    time.sleep(3)
    # e.set()
    print 'main: event is set'
 
 
#练习:condition 等待notify_all() notify()
import threading as tr
import time
def consumer(cond):
    with cond:
        print("consumer before wait")
        cond.wait() # 等待消费
        print("consumer after wait")
 
def producer(cond):
    with cond:
        print("producer before notifyAll")
        cond.notify_all() # 通知消费者可以消费了
        print("producer after notifyAll")
 
if __name__ == '__main__':   
    condition = tr.Condition()
 
    t1 = tr.Thread(name = "thread-1", target = consumer, args=(condition,))
    t2 = tr.Thread(name = "thread-2", target = consumer, args=(condition,))
    t3 = tr.Thread(name = "thread-3", target = producer, args=(condition,))
 
    t1.start()
    time.sleep(2)
    t2.start()
    time.sleep(2)
    t3.start()
 
 
 
#练习:线程队列 队列是一种数据结构
from threading import Thread
from Queue import Queue  
import random, time
 
# 储钱罐
def create(queue):  
    for i in [100, 50, 20, 10, 5, 1, 0.5]:
      if not queue.full():
        queue.put(i)  # 入队列
        print 'Put %sRMB to queue.' %i
        time.sleep(1)
 
# 取储钱罐中的零钱花
def get(queue):
  while 1:
    if not queue.empty():
      print 'Get %sRMB from queue.' %queue.get()
      time.sleep(2)
    else:
      break 
 
if __name__=="__main__":
    q = Queue() # 创建一个队列实例
    create_t = Thread(target = create, args = (q,))  
    get_t = Thread(target = get, args = (q,))  
    create_t.start() 
    #time.sleep(1) #这里稳妥起见,最好是sleep1秒
    get_t.start()
    create_t.join()
    get_t.join()
 
 
#练习:死锁 互相等,结果谁也等不到谁
 
import threading  
import time
 
#声明全局锁 不用global直接用
lock1 = threading.Lock()  
lock2 = threading.Lock()  
print lock1, lock2
class T1(threading.Thread):  
    def __init__(self, name):  
        threading.Thread.__init__(self)  
        self.t_name = name  
 
    def run(self):  
        lock1.acquire()  
        time.sleep(1)#睡眠的目的是让线程2获得调度,得到第二把锁
        print 'in thread T1',self.t_name
        time.sleep(2) 
        lock2.acquire() #线程1请求第二把锁
        print 'in lock l2 of T1'  
        lock2.release()      
        lock1.release() 
 
class T2(threading.Thread):  
    def __init__(self, name):  
        threading.Thread.__init__(self)  
        self.t_name = name  
 
    def run(self):  
        lock2.acquire()  
        time.sleep(2)#睡眠的目的是让线程1获得调度,得到第一把锁
        print 'in thread T2',self.t_name
        lock1.acquire() #线程2请求第一把锁
        print 'in lock l1 of T2'
        lock1.release() 
        lock2.release() 
 
def test():  
    thread1 = T1('A')  
    thread2 = T2('B')  
    thread1.start()  
    thread2.start()  
 
if __name__== '__main__':  
    test()

【Python】多线程-3的更多相关文章

  1. python多线程学习记录

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

  2. python多线程编程

    Python多线程编程中常用方法: 1.join()方法:如果一个线程或者在函数执行的过程中调用另一个线程,并且希望待其完成操作后才能执行,那么在调用线程的时就可以使用被调线程的join方法join( ...

  3. Python 多线程教程:并发与并行

    转载于: https://my.oschina.net/leejun2005/blog/398826 在批评Python的讨论中,常常说起Python多线程是多么的难用.还有人对 global int ...

  4. python多线程

    python多线程有两种用法,一种是在函数中使用,一种是放在类中使用 1.在函数中使用 定义空的线程列表 threads=[] 创建线程 t=threading.Thread(target=函数名,a ...

  5. python 多线程就这么简单(转)

    多线程和多进程是什么自行google补脑 对于python 多线程的理解,我花了很长时间,搜索的大部份文章都不够通俗易懂.所以,这里力图用简单的例子,让你对多线程有个初步的认识. 单线程 在好些年前的 ...

  6. python 多线程就这么简单(续)

    之前讲了多线程的一篇博客,感觉讲的意犹未尽,其实,多线程非常有意思.因为我们在使用电脑的过程中无时无刻都在多进程和多线程.我们可以接着之前的例子继续讲.请先看我的上一篇博客. python 多线程就这 ...

  7. python多线程监控指定目录

    import win32file import tempfile import threading import win32con import os dirs=["C:\\WINDOWS\ ...

  8. python多线程ssh爆破

    python多线程ssh爆破 Python 0x01.About 爆弱口令时候写的一个python小脚本,主要功能是实现使用字典多线程爆破ssh,支持ip表导入,字典数据导入. 主要使用到的是pyth ...

  9. 【python,threading】python多线程

    使用多线程的方式 1.  函数式:使用threading模块threading.Thread(e.g target name parameters) import time,threading def ...

  10. <转>Python 多线程的单cpu与cpu上的多线程的区别

    你对Python 多线程有所了解的话.那么你对python 多线程在单cpu意义上的多线程与多cpu上的多线程有着本质的区别,如果你对Python 多线程的相关知识想有更多的了解,你就可以浏览我们的文 ...

随机推荐

  1. miniui 使用心得

    MiniUI demo实例使用心得:1.渲染速度很快2快速维护数据 3多种编辑方式 如 弹窗 直接下方显示form 下方显示tab 等4.树形 编辑 联动 5验证表单6文本框内 选择框 保存的多个选项 ...

  2. Lucene.Net 学习(搜索部分)(低要求,写给自己看)

    1. 搜索 排序:lucene 提供了Sort类对结果进行排序 提供了Filter类对查询条件进行限制 你或许会不自觉地拿它跟SQL语句进行比较:“lucene能执行and.or.order by.w ...

  3. 【转】Vue-详解设置路由导航的两种方法: <router-link :to="..."> 和router.push(...)

    一.<router-link :to="..."> to里的值可以是一个字符串路径,或者一个描述地址的对象.例如: // 字符串 <router-link to= ...

  4. Linux安装/卸载软件教程

    一.源码安装 ./configure #环境检查.生成makefile make #编译 make install #安装 这三条命令是最经典的Linux软件安装,适用于所有发行版 二.软件包管理工具 ...

  5. [转]java nio解决半包 粘包问题

    java nio解决半包 粘包问题 NIO socket是非阻塞的通讯模式,与IO阻塞式的通讯不同点在于NIO的数据要通过channel放到一个缓存池ByteBuffer中,然后再从这个缓存池中读出数 ...

  6. Mysql设置自增字段的方法

    #int : 字段类型 alter table 表名 modify 字段名 int auto_increment primary key

  7. 转:Java工程师成神之路~(2018修订版)

    转: http://www.hollischuang.com/archives/489 阿里大牛珍藏架构资料,点击链接免费获取 针对本文,博主最近在写<成神之路系列文章> ,分章分节介绍所 ...

  8. secFox setting

    secFox setting   1● load file 2● install 3● use  

  9. Taking water into exams could boost grades 考试带瓶水可以提高成绩?

    Takeing a bottle of water into the exam hall could help students boost their grades, researchers cla ...

  10. x=x+1, x += 1, x++ 效率分析

    x = x + 1 效率最低 具体如下: 1. 读取右x的地址 2. x + 1 3. 读取左x的地址 4. 将右值传给左边的x(编译器不认为左x和右x是同一个地址) x += 1 其次 1. 读取右 ...