主要学习一下python的多线程编程,使用threading模块,threading 包括:Thread、conditions、event、rlock、semaphore等类。

Thread对象可以实例化一个线程t,在创建t线程时,可以将t的主函数作为一个参数传递进去(target=),或者创建Thread的子类覆盖run方法。在Thread实例化线程t后,t并没有运行,要想让t线程活动,必须启动t,t.start()即可,一旦t是活动的,t将在其主函数结束时结束。在Thread实例化一个线程时必须指定target。

Thread的方法如下:

getname可以返回线程t的名称,setname设置线程t的名称
       isalive 判断一个线程是否是活动的,也就是线程状态在t.start和t.run之间
       isdaemon/setdaemon 如果线程t是一个驻留程序(即使t是活动的,python也可以终止整个处理过程,也会将t结束),isdaemon返回ture,仅当创建t的线程是一个驻留程序时,线程t才是一个驻留程序,这样只能在t.start()之前调用t.setdaemon来设置t为一个驻留程序。
       join 其他调用线程(非t)会直接挂起,直到t结束,只能在t.start之后调用t.join
       run run是运行线程t主函数的方法,thread的子类通常会覆盖run,如果不被覆盖,run将调用在创建t时传递的target参数,通过t.start()调用t.run
       start t.start()让线程t活动

线程同步对象:
      timeout 在event和condition中都有一个可以接收一个可选的timeout参数作为wait方法
      lock/rlock threading的lock和thread的lock一样,rlock是一个重入锁,在r被锁定时,r将跟踪所有者(锁定r的哪个)线程,所有者线程可以再次调用r.acquire而不会出现阻塞,r只是将内部计数器加1。而lock则会永远阻塞。
       condition 创建返回一个condition对象c,c可以包装一个lock或者rlock对象L,acquire/release 这些方法将调用L的对应方法,前提是一个线程拥有对L的锁。notify/notifyall notify可以唤醒正在等待c的线程中的某一个线程,调用线程在调用c.notify()之前必须拥有L,并且notify不会释放L。调用线程通常会在调用notify之后调用release。
       wait wait将释放L,然后挂起调用线程,直到其他线程对c调用notify
       event对象可以让任意数量的线程挂起并等待。

threading模块提供了一个local类,称为TLS,在一个线程中做的任何更改不会对其他线程产生影响

编程代码如下:
#!/usr/bin/python
import sys
import time
import threading
 
b=50
l=threading.Lock()
 
def threadcode():
    global b
    print "Thread %s invoke" % threading.currentThread().getName()
    l.acquire()
    try:
        print "Thread %s is running" % threading.currentThread().getName()
        time.sleep(30)
        b=b+50
        print "Thread %s set b to %d" % (threading.currentThread().getName(),b)
    finally:
        l.release()
 
print "Value of b at start program:",b
 
childthread=[]
for i in range(1,5):
    t=threading.Thread(target=threadcode,name="Thread-%d" % i)
    t.start()
    childthread.append(t)
for i in childthread:
    t.join()
 
print "New value of b:",b
测试图如下:

Python2.7 threading模块学习的更多相关文章

  1. Python2.7 Queue模块学习

    前面了解了一下threading,发现一般都是和queue模块配合使用的,queue产生一个队列,队列模式有3种,针对这三种队列分别有三个构造函数: 1 FIFO队列先进先出:class Queue. ...

  2. python进阶笔记 thread 和 threading模块学习

    Python通过两个标准库thread和threading提供对线程的支持.thread提供了低级别的.原始的线程以及一个简单的锁.threading基于Java的线程模型设计.锁(Lock)和条件变 ...

  3. Python学习笔记- Python threading模块

    Python threading模块 直接调用 # !/usr/bin/env python # -*- coding:utf-8 -*- import threading import time d ...

  4. Python模块学习:threading 多线程控制和处理

    Reference:http://python.jobbole.com/81546/ threading.Thread Thread 是threading模块中最重要的类之一,可以使用它来创建线程.有 ...

  5. Python模块学习------ 多线程threading(2)

    一.避免使用thread模块,使用threading模块的原因: 1. 更高级别的threading模块更为先进,对线程的支持更加完善.而且使用thread模块的属性有可能会与threading 出现 ...

  6. python学习笔记之使用threading模块实现多线程(转)

    综述 Python这门解释性语言也有专门的线程模型,Python虚拟机使用GIL(Global Interpreter Lock,全局解释器锁)来互斥线程对共享资源的访问,但暂时无法利用多处理器的优势 ...

  7. threading模块和queue模块实现程序并发功能和消息队列

    简介: 通过三个例子熟悉一下python threading模块和queue模块实现程序并发功能和消息队列. 说明:以下实验基于python2.6 基本概念 什么是进程? 拥有独立的地址空间,内存,数 ...

  8. python threading基础学习

    # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' """ python是支持多线程的,并 ...

  9. python 多线程编程之threading模块(Thread类)创建线程的三种方法

    摘录 python核心编程 上节介绍的thread模块,是不支持守护线程的.当主线程退出的时候,所有的子线程都将终止,不管他们是否仍在工作. 本节开始,我们开始介绍python的另外多线程模块thre ...

随机推荐

  1. JS 时间差计算 XX秒前、XX小时前、XX天前

    //时间差 function GetTime(time) {//di作为一个变量传进来 //如果时间格式是正确的,那下面这一步转化时间格式就可以不用了 var dateBegin = new Date ...

  2. memory management Vulkan

    https://www.youtube.com/watch?v=rXSdDE7NWmA vulkan 1. DEVICE_LOCAL_BIT | HOST_VISIBLE_BIT | HOST_COH ...

  3. 特殊变量的处理(一)onehot&dummy

    表述类目的变量通常,通常没有次序概念,且取值范围有限.例如性别行业信用卡类型.有些模型可以直接读类别变量(例如决策树).有些模型不能识别类别变量(例如回归模型,神经网络,有距离的度量模型(svn,kn ...

  4. queue的一些用法

    import queue q = queue.Queue(3)# 指定队列大小,如果为空则为无限大 print(q.empty()) q.put('厉智') q.put('程劲') q.put('陈培 ...

  5. 《Redis 设计与实现》读书笔记(二)

    单机数据库实现 九.数据库 1.服务器中的数据库 一个redis服务器保存多个数据库. struct redisServer { //一个数组,多个数据库 redisDb *db; } 当执行sele ...

  6. sql防止注入的技巧

    from Stack Overflow Here is a similar solution which I think is more efficient in building up the li ...

  7. 【Android-关闭所有Activity】关闭activity之前的所有activity,重启actibity

    Android关闭activity之前的所有activity,重启actibity 直接关闭一个activity之前的所有Activity页面 解决方法:清理activity堆栈 Intent ine ...

  8. nginx+tomcat遇到的https重定向到http问题

    nginx做反向代理时,需要把请求头信息一起发送给tomcat,不然tomcat中的域名绑定就无法发挥作用了. 今天又遇到https请求被拦截器重定向到登陆页居然变成http的问题,导致小程序无法访问 ...

  9. 去掉amcharts4图表上的logo

    引用了amcharts的图表工具,但右下角会显示amcharts 的图形LOGO,如下图: 而且每个图表上都有这个代码.看了一下代码里,找到这些LOGO,发现都有如下特征: aria-labelled ...

  10. 装饰者模式(Decorator)---结构型

    1 基础知识 定义:在不改变原有对象的基础上,将功能附加到对象上即动态地给一个对象添加一些额外的职责.特征:提供了比继承更有弹性的替代方案. 本质:动态组合. 使用场景:扩展一个类的功能或给一个类添加 ...