Python 的多线程模块(threading)

1.

 1 #coding=utf-8
 2 import threading
 3 from time import ctime,sleep
 4
 5
 6 def music(func):
 7     for i in range(2):
 8         print "I was listening to %s. %s" %(func,ctime())
 9         sleep(1)
10
11 def move(func):
12     for i in range(2):
13         print "I was at the %s! %s" %(func,ctime())
14         sleep(5)
15
16 threads = []
17 t1 = threading.Thread(target=music,args=(u‘爱情买卖‘,))
18 threads.append(t1)
19 t2 = threading.Thread(target=move,args=(u‘阿凡达‘,))
20 threads.append(t2)
21
22 if __name__ == ‘__main__‘:
23     for t in threads:
24         t.setDaemon(True)
25         t.start()
26
27     print "all over %s" %ctime()
时间: 2024-11-06 09:46:04

Python 的多线程模块(threading)的相关文章

Python之多线程:Threading模块

1.Threading模块提供的类 Thread,Lock,Rlock,Condition,Semaphore,Event,Timer,local 2.threading模块提供的常用的方法 (1)threading.currentThread(): 返回当前的线程变量. (2)threading.enumerate(): 返回一个包含正在运行的线程的list.正在运行指线程启动后.结束前,不包括启动前和终止后的线程. (3)threading.activeCount():返回正在运行的线程数量

Python的多线程和多进程模块对比测试

本文主要对比测试Python的多线程和多进程模块在CPU类型和I/O的任务操作时的效率 一 测试CPU消耗类型任务 在一台多核CPU的服务器上执行多线程代码,理论上代码执行时会利用多余的CPU核心来提升性能.但是由于Python的GIL的存在,使用多线程来执行CPU繁重的任务,未必能得到性能提升.但是GIL又必不可少,因为在Python解释器中执行线程是不安全的,也就是说为了保证Python线程执行时的安全,Python提供了一个全局锁,同一时刻,只允许一个线程获得这个全解锁并执行. CPU消耗

Python 的多进程模块(multiprocessing)

Python的多进程 Python 的MD5模块 try-except-finally的使用方法:finally最后关闭一些东西. Python的多线程模块 Python的pika模块 mq模块出现错误: rabbitting 命令教程: http://zhanghua.1199.blog.163.com/blog/static/4644980720128119320348/

Python多线程(threading)学习总结

注:此文除了例子和使用心得是自己写的,很多都是Python核心编程中的原文.原文文风应该能看出来,就不每个地方单独表明出处了. 线程(有时被称为轻量级进程)跟进程有些相似,不同的是,所有的线程运行在同一个进程中,共享相同的运行环境.它们可以想像成是在主进程或"主线程"中并行运行的"迷你进程". 线程有开始,顺序执行和结束三部分.它有一个自己的指令指针,记录自己运行到什么地方.线程的运行可能被抢占(中断),或暂时的被挂起(也叫睡眠),让其它的线程运行,这叫做让步.一个

Python多线程模块

引言 thread threading 1 Thread 11 下面使用threading模块实现与上面相同的功能 12 在创建新线程时还可以给Thread传递可调用类的对象这样使用类本身来保存信息 如 13 从Thread派生一个子类然后创建这个子类的实例 14 实例 Queue 0. 引言 在Python中可使用的多线程模块主要有两个,thread和threading模块.thread模块提供了基本的线程和锁的支持,建议新手不要使用.threading模块允许创建和管理线程,提供了更多的同步

Python 多线程 -thread threading Queue- 简单学习

在实际工作过程中,会出现需要并发的做一些事情,例如一台机器测到几千台机器的网络连通性,如果你单线程一台一台测的话,会花费很多的事情,不具有实时性,更不能在变化的时候立刻感知当时网络的状况,这时多线程就是一个很好地选择.python已经给我们封装好了多线程库thread和threading. thread:比较底层的模块 threading:Higher-level threading interface ps:建议使用threading模块 - 高级别的threading模块更为先进,对线程的支

Python的多线程threading和多进程multiprocessing

python中的多线程就是在一个进程中存在着多个线程,在线程中,所有的线程都是共享资源的,线程之间的数据通信很简单.但是python仅支持一个线程的运行,因为python中存在一个全局解释器锁GIL(global interpreter lock),正是这个锁能保证同一时刻只有一个线程在运行,所以多线程依旧像是单线程的运行. GIL无疑就是一把对多线程有影响的全局锁,解决它对多线程的影响,不单单是释放GIL这么简单.GIL使得对象模型都是可以并发访问.GIL全局解释器锁解决多线程之间数据完整性和

基于Python的urllib2模块的多线程网络爬虫程序

1 m Queue import Queue 2 from gzip import GzipFile 3 from StringIO import StringIO 4 import time 5 import socket 6 class ContentEncodingProcessor(urllib2.BaseHandler): 7 """A handler to add gzip capabilities to urllib2 requests ""

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

python中_thread模块是一个低级别的多线程模块,它的问题在于主线程运行完毕后,会立马把子线程给结束掉,不加处理地使用_thread模块是不合适的.这里把书中讲述的有关_thread使用的例子自己实现了一遍,做以记录. #例子一:自己手动在主线程中设置等待时间import _thread from time import ctime, sleep def loop0(): print("loop0 starts at:{}".format(ctime())) sleep(4)