python 线程(thread)
#coding:utf-8
#多线程
#Python的标准库提供了两个模块:thread和threading,thread是低级模块,threading是高级模块,对thread进行了封装
#绝大数情况下,我们只需要使用threading这个高级模块
#启动一个线程就是把一个函数传入并创建Thread实例,然后调用start()开始执行
import time,threading
def loop():
print 'thread %s is runing...' % threading.current_thread().name
n = 0
while n < 5:
n = n + 1
print 'thread %s >>> %s' %(threading.current_thread().name,n)
time.sleep(1)
print 'thread %s ended' %threading.current_thread().name
print 'thread %s is running' %threading.current_thread().name
#创建一个线程对象,参数1为函数名字,参数name为线程名字
t = threading.Thread(target = loop,name = 'LoopThread')
#启动线程
t.start()
#阻塞主线程等待LoopThread线程执行完毕
t.join()
print 'thread %s ended' %threading.current_thread().name
多线程中的锁
#coding:utf-8
#多线程和多进程的不同在于,多进程中,同一个变量,各自有一份拷贝存在于每个进程中,互不影响,而多线程中,所有变量都由所有线程共享
#所以,任何一个变量都可以被任何一个线程修改,因此,线程之间共享数据最大的危险在于多个线程同时修改一个变量
#我们定义了一个共享变量balance,初始值为0,并且启动两个线程,先存后取,理论上结果应该为0,但是,由于
#线程的调度是由操作系统决定的t1,t2交替执行时,只要循环次数足够多,balance的结果就不一定是0了
import threading,time
balance = 0
#获取一个锁对象
lock = threading.Lock()
def change_it(n):
global balance
balance = balance + n
balance = balance - n
def run_thread(n):
for i in range(100000):
#获得锁
lock.acquire()
try:
change_it(n)
finally:
#改完了一定要释放锁
lock.release()
t1 = threading.Thread(target = run_thread,args =(5,))
t2 = threading.Thread(target = run_thread,args = (8,))
t1. start()
t2.start()
t1.join()
t2.join()
print balance
#如果我们要确保balance计算正确, 就要给change_its上一把锁,当某个线程开始执行change_it()时,我们
#说该线程获得了锁,因此其他线程不能同时执行change_it()只能等待,直到锁被释放后,获得该锁以后才能改
#由于锁只有一个,无论多少线程,同一时刻最多只有一个线程持有该锁,所以不会造成修改的冲突。创建一个锁
#就是通过threding.Lock()来实现
ThreadLocal
#coding:utf-8
#在多线程环境下,每个线程都有自己的数据。一个线程使用自己的局部变量比使用全局变量好,
#因为局部变量只有线程自己能看见,不会影响其他线程,而全局变量的修改必须加锁。
#但是局部变量也有问题,就是在函数调用的时候,传递起来很麻烦
#ThreadLocal应运而生
import threading
#创建全局ThreadLocal对象
local_school = threading.local()
def process_student():
print 'Hello %s (in %s)' % (local_school.student,threading.current_thread().name)
def process_thread(name):
#绑定ThreadLocal的student
local_school.student = name
process_student()
#创建线程对象1
t1 = threading.Thread(target = process_thread, args =('paulversion',),name = 'Thread-A')
#创建线程对象2
t2 = threading.Thread(target = process_thread,args =('Floki',),name = 'Thread-B')
t1.start()
t2.start()
t1.join()
t2.join()
#全局变量local_school 就是一个ThreadLocal对象,每个Thread对它都可以读取student属性,单互不影响,你可以把local_shool看成全局变量
#但每个属性如local_school.student都是线程的局部变量,可以任意读写而互不干扰,也不用管理锁的问题,ThreadLocal内部 会处理
#可以理解为全局变量local_school是一个dict,不但可以用local_school.student,还可以绑定其他变量,如local_school.teacher等等
#Threadlocal最常用的地方就是为每个线程绑定一个数据库连接
python 线程(thread)的更多相关文章
- python 线程创建和传参(28)
在以前的文章中虽然我们没有介绍过线程这个概念,但是实际上前面所有代码都是线程,只不过是单线程,代码由上而下依次执行或者进入main函数执行,这样的单线程也称为主线程. 有了单线程的话,什么又是多线程? ...
- python——线程与多线程进阶
之前我们已经学会如何在代码块中创建新的线程去执行我们要同步执行的多个任务,但是线程的世界远不止如此.接下来,我们要介绍的是整个threading模块.threading基于Java的线程模型设计.锁( ...
- python——线程与多线程基础
我们之前已经初步了解了进程.线程与协程的概念,现在就来看看python的线程.下面说的都是一个进程里的故事了,暂时忘记进程和协程,先来看一个进程中的线程和多线程.这篇博客将要讲一些单线程与多线程的基础 ...
- [python] 线程简介
参考:http://www.cnblogs.com/aylin/p/5601969.html 我是搬运工,特别感谢张岩林老师! python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件 ...
- PYTHON线程知识再研习A
前段时间看完LINUX的线程,同步,信息号之类的知识之后,再在理解PYTHON线程感觉又不一样了. 作一些测试吧. thread:模块提供了基本的线程和锁的支持 threading:提供了更高级别,功 ...
- Python 线程(threading) 进程(multiprocessing)
*:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...
- python线程与进程手记
------------------------------线程---------------------------#线程应用的第一种方式:thread模块是比较底层的模块#import threa ...
- Python线程:线程的调度-守护线程
Python线程:线程的调度-守护线程 守护线程与普通线程写法上基本么啥区别,调用线程对象的方法setDaemon(true),则可以将其设置为守护线程.在python中建议使用的是thread. ...
- python 线程(一)理论部分
Python线程 进程有很多优点,它提供了多道编程,可以提高计算机CPU的利用率.既然进程这么优秀,为什么还要线程呢?其实,仔细观察就会发现进程还是有很多缺陷的. 主要体现在一下几个方面: 进程只能在 ...
随机推荐
- MySQL数据库分片技术调研
将这段时间了解的MySQL分片技术和主从复制只是整理清楚画了思维导图记录一下,希望能给需要的人一些帮助 P.S.:个人整理,可能会有错误之处,还望指出~ 要解决的问题 1.海量数据的操作超出单表.单库 ...
- 分页 返回 json格式数据
分页工具类PageBean.java package org.activeii.activeii.app.person.util; import java.util.List; public clas ...
- javascript中按位操作的应用,如何快速取整 判断字符串是否是包含某字符串
最近在看最基础的<javascript高级程序设计>看的灰常慢,看到按位运算这里,突然反思,这种鬼操作到底有什么实际的应用呢? 按位运算符有6个 & 按位与:a & b | ...
- 倍福TwinCAT(贝福Beckhoff)常见问题(FAQ)-如何获取标准驱动器扭矩值获取电流值
双击某个驱动器(以松下伺服驱动器为例),在Process Data中,注意默认显示了PDO mapping1的数据(Error code, status word等) 注意左侧,2和3分别表示了与 ...
- JUnit4.8.2源码分析-1 说明
阅读本系列文章时须要知道的: JUnit是由GOF 之中的一个的Erich Gamma和 Kent Beck 编写的一个开源的单元測试框架,分析JUnit源码的主要目的是学习当中对设计模式的运用.JU ...
- Tomcat中work目录的作用
今天在修改了某个jsp后发现:tomcat容器启动后,访问该jsp返回的结果依然是修改之前的内容,略感不解,于是乎研究了一下Tomcat中work目录的作用. Tomcat中work目录的作用: js ...
- 阿里云OSS设置跨域访问
OSS 提供 HTML5 协议中的跨域资源共享 CORS 设置,帮助您实现跨域访问.当 OSS 收到一个跨域请求(或者 OPTIONS 请求)时,会读取存储空间对应的 CORS 规则,然后进行相应的权 ...
- Cocos2dx报OpenGL error 0x0506错误
近期做第三方sdk接入时,发现iOS8系统下,进行银联充值后,返回游戏有很大几率会报 OpenGL error 0x0506............ 之类的绘制问题,游戏卡死,花了很长时间,一直没有头 ...
- 《C#程序设计教程 -李春保》阅读笔记
<C#程序设计教程 -李春保>阅读笔记 ( 需注意程度:红>粗体>下划线,蓝色:我的疑问 ) 老师的引言 [师]对待一种新语言的关注点 数据类型定义(python不用定 ...
- ImageBox Control with Zoom/Pan Capability
Download source files - 10.8 Kb Download demo project - 6.81 Kb Introduction This control extends th ...