Python2.7 threading模块学习
主要学习一下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模块学习的更多相关文章
- Python2.7 Queue模块学习
前面了解了一下threading,发现一般都是和queue模块配合使用的,queue产生一个队列,队列模式有3种,针对这三种队列分别有三个构造函数: 1 FIFO队列先进先出:class Queue. ...
- python进阶笔记 thread 和 threading模块学习
Python通过两个标准库thread和threading提供对线程的支持.thread提供了低级别的.原始的线程以及一个简单的锁.threading基于Java的线程模型设计.锁(Lock)和条件变 ...
- Python学习笔记- Python threading模块
Python threading模块 直接调用 # !/usr/bin/env python # -*- coding:utf-8 -*- import threading import time d ...
- Python模块学习:threading 多线程控制和处理
Reference:http://python.jobbole.com/81546/ threading.Thread Thread 是threading模块中最重要的类之一,可以使用它来创建线程.有 ...
- Python模块学习------ 多线程threading(2)
一.避免使用thread模块,使用threading模块的原因: 1. 更高级别的threading模块更为先进,对线程的支持更加完善.而且使用thread模块的属性有可能会与threading 出现 ...
- python学习笔记之使用threading模块实现多线程(转)
综述 Python这门解释性语言也有专门的线程模型,Python虚拟机使用GIL(Global Interpreter Lock,全局解释器锁)来互斥线程对共享资源的访问,但暂时无法利用多处理器的优势 ...
- threading模块和queue模块实现程序并发功能和消息队列
简介: 通过三个例子熟悉一下python threading模块和queue模块实现程序并发功能和消息队列. 说明:以下实验基于python2.6 基本概念 什么是进程? 拥有独立的地址空间,内存,数 ...
- python threading基础学习
# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' """ python是支持多线程的,并 ...
- python 多线程编程之threading模块(Thread类)创建线程的三种方法
摘录 python核心编程 上节介绍的thread模块,是不支持守护线程的.当主线程退出的时候,所有的子线程都将终止,不管他们是否仍在工作. 本节开始,我们开始介绍python的另外多线程模块thre ...
随机推荐
- Collection 和 Collections 有什么区别?(未完成)
Collection 和 Collections 有什么区别?(未完成)
- linux和unix下crontab的使用
在LINUX中,周期执行的任务一般由cron这个守护进程来处理 [ps -ef | grep cron].cron读取一个或多个配置文件,这些配置文件中包含了命令行及其调用时间.cron的配置文件称为 ...
- JAVA8初探-让方法参数具备行为能力并引入Lambda表达式
关于JAVA8学习的意义先来贴一下某网站上的对它的简单介绍:“Java 8可谓Java语言历史上变化最大的一个版本,其承诺要调整Java编程向着函数式风格迈进,这有助于编写出更为简洁.表达力更强,并且 ...
- python_连接MySQL数据库(未完)
1.增 # 导入库 import pymysql # 创建连接 conn = pymysql.connect(host='localhost',user='root',password='fuqian ...
- Django的 select_related 和 prefetch_related 函数对 QuerySet 查询的优化
引言 在数据库存在外键的其情况下,使用select_related()和prefetch_related()很大程度上减少对数据库的请求次数以提高性能 1.实例准备 模型: from django.d ...
- 前端知识体系:JavaScript基础-变量和类型
前端工程师自检清单 1. JavaScript规定了几种语言类型 2. JavaScript对象的底层数据结构是什么 3. Symbol类型在实际开发中的应用.可手动实现一个简单的 Symbo 4. ...
- C语言例题
1.连接两个字符串 将两个字符串连接,不要用stract函数 2.求矩阵外围元素之和 求3行3列矩阵的外围元素之和. 3.求矩阵主对角线和副对角线元素之和 求5行5列矩阵的主对角线和副对角线元素之和. ...
- CCPC 2017 哈尔滨 D. X-Men && HDU 6233(思维+期望)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6233 题意:一个树上有m个人,每个人在某个节点上,每个时刻每个人可以和一个与他距离大于 1 的点进行交 ...
- [Svelte 3] Use an onMount lifecycle method to fetch and render data in Svelte 3
Every Svelte component has a lifecycle that starts when it is created, and ends when it is destroyed ...
- hdfs基本使用
基本命令 /usr/local/hadoop/bin/hadoop fs -ls / /usr/local/hadoop/bin/hadoop fs -mkdir /test # 创建目录 /usr/ ...