《Python核心编程》18.多线程编程(二)
18.1没有线程支持
#!/usr/bin/env python
# -*- coding:utf-8 -*-
from time import sleep, ctime def loop0():
print 'start loop 0 at:', ctime()
sleep(4)
print 'loop 0 done at', ctime() def loop1():
print 'start loop 1 at:', ctime()
sleep(2)
print 'loop 1 done at:', ctime() def main():
"""顺序执行两个循环,即第一个循环执行完毕,才能执行第二个"""
print 'staring at:', ctime()
loop0()
loop1()
print 'all DONE at:', ctime() if __name__ == '__main__':
main()
18.2thread线程支持
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import thread
from time import sleep,ctime def loop0():
print 'start loop 0 at:', ctime()
sleep(4)
print 'loop 0 done at:', ctime() def loop1():
print 'start loop 1 at:', ctime()
sleep(2)
print 'loop 1 done at:', ctime() def main():
print 'starting at:', ctime()
thread.start_new_thread(loop0, ())
# 函数start_new_thread()产生一个新线程来运行函数loop0() thread.start_new_thread(loop1, ())
# 同上,两个线程同同时运行 sleep(6) # 主线程睡眠等待;如果主线程(此程序本身)没有停下来,就会直接运行下一条语句,不会等待两个线程运行完毕
print 'all DONE at: ', ctime() if __name__ == '__main__':
main()
18.3 使用线程和锁
#!/usr/bin/env python
# -*- coding:utf-8 -*- import thread
from time import sleep, ctime loops = [4, 2]
# 1储存每个循环的睡眠时间
# 2间接说明了循环的个数 def loop(nloop, nsec, lock):
"""记录循环的号码和睡眠时间,并添加锁"""
print 'start loop', nloop, 'at:', ctime()
sleep(nsec)
print 'loop', nloop, 'done at:', ctime()
lock.release() # 当sleep()时间结束,释放锁用以通知主线程,此子线程已结束 def main():
"""包含三个循环:创建锁;创建线程并分配锁;线程结束并解锁"""
print 'Starting at:', ctime()
locks = []
nloops = range(len(loops)) # 利用列表元素个数说明循环次数 for i in nloops:
lock = thread.allocate_lock() # allocate_lock()函数分配锁对象
lock.acquire() # 获取锁对象
locks.append(lock) # 创建锁列表 for i in nloops:
thread.start_new_thread(loop, (i, loops[i], locks[i])) # 创建循环线程 for i in nloops:
while locks[i].locked(): # 主线程对锁对象进行检查(暂停主线程)。当有线程结束,解锁,主线程才执行下条语句
pass print 'all DONE at:', ctime() if __name__ == '__main__':
main()
18.4使用threaging 模块
#!usr/bin/env python
# -*- coding:utf-8 -*- """创建一个Thread(threading模块中的类)的实例,传给它一个函数""" import threading
from time import sleep, ctime loops = [4, 2]
# 1储存每个循环的睡眠时间
# 2间接说明了循环的个数 def loop(nloop, nsec):
"""1记录循环的号码 2记录睡眠时间"""
print 'start loop', nloop, 'at:', ctime()
sleep(nsec)
print 'loop', nloop, 'done at:', ctime() def main():
print 'starting at:', ctime()
threads = []
nloops = range(len(loops)) # 记录循环次数 for i in nloops:
t = threading.Thread(target=loop, args=(i, loops[i]))
# 1实例化Thread类对象,将函数(target)和参数(args)传入,得到返回的Thread实例:线程对象t。
# 2实例化(调用)Thread类时,不会像thread.star_new_thread那样,线程立即开始,这样可以更好的同步。
threads.append(t) # 创建对象列表 for i in nloops:
threads[i].start() # 开始线程的执行 for i in nloops:
threads[i].join()
# 1调用join()方法后,主线程会等到线程结束才执行下条语句,相比使用等待锁释放的无线循环(自旋锁)更为清楚。
# 2若主线程除了等待线程结束外,还有其他事情要做(如处理或等待其他的客户请求),就不用调用join()。主线程
# 依然会等待线程执行完毕。 print 'all DONE at:', ctime() if __name__ == '__main__':
main()
18.5使用threading模块
#!/usr/bin/env python
# -*- coding:utf-8 -*- """创建一个Thread实例,传给它一个可调用的类对象""" import threading
from time import sleep, ctime loops = [4, 2]
# 1储存每个列表的循环时间
# 2间接说明循环的个数 class ThreadFunc(object):
"""
想让这个类在调用函数方面尽量地通用,并不局限与loop()函数。
这个类保存了函数本身,函数的参数,以及函数名字的字符串。
构造函数__init__()中做了这些值的赋值操作。
""" def __init__(self, func, args, name=''):
super(ThreadFunc, self).__init__()
self.name = name
self.func = func
self.args = args def __call__(self): # 用来执行类中的函数
self.func(*self.args) def loop(nloop, nsec):
print 'start loop', nloop, 'at:', ctime()
sleep(nsec)
print 'loop', nloop, 'done at:', ctime() def main():
print 'starting at:', ctime()
threads = []
nloops = range(len(loops)) for i in nloops:
t = threading.Thread(target=ThreadFunc(loop, (i, loops[i]), loop.__name__))
# 1.实例化Thread对象时,同时也会实例化ThreadFunction对象,即实例化了两个对象
# 2.由于已经有了要用的参数,就不用额外添加参数到Thread()的构造器中
# 3.这里时传送类对象,而18.4中传送的是函数 threads.append(t) for i in nloops:
threads[i].start() for i in nloops:
threads[i].join() print 'all DONE at:', ctime() if __name__ == '__main__':
main()
《Python核心编程》18.多线程编程(二)的更多相关文章
- Java多线程编程(2)--多线程编程中的挑战
一.串行.并发和并行 为了更清楚地解释这三个概念,我们来举一个例子.假设我们有A.B.C三项工作要做,那么我们有以下三种方式来完成这些工作: 第一种方式,先开始做工作A,完成之后再开始做工作B ...
- 进阶Java编程(1)多线程编程
Java多线程编程 1,进程与线程 在Java语言里面最大的特点是支持多线程的开发(也是为数不多支持多线程的编程语言Golang.Clojure方言.Elixir),所以在整个的Java技术学习里面, ...
- SDK编程之多线程编程
本课中,我们将学习如何进行多线程编程.另外我们还将学习如何在不同的线程间进行通信. 理论:前一课中,我们学习了进程,其中讲到每一个进程至少要有一个主线程.这个线程其实是进程执行的一条线索,除此主线程外 ...
- 廖雪峰Java13网络编程-1Socket编程-3TCP多线程编程
TCP多线程编程 一个ServerSocket可以和多个客户端同时建立连接,所以一个Server可以同时与多个客户端建立好的Socket进行双向通信. 因此服务器端,当我们打开一个Socket以后,通 ...
- 《Python核心编程》18.多线程编程(三)
18.6使用threading模块 #!/usr/bin/env python # -*- coding:utf-8 -*- """从Thread类中派生出一个子例,创建 ...
- 《Python核心编程》 18.多线程编程(一)
一进程和线程 1参考链接: http://www.zhihu.com/question/25532384 中OF小工和zhonyong 的回答 总结他们两的回答: 引言: 1.电脑的运行,在硬件上是C ...
- 18 多线程编程 - 《Python 核心编程》
- python核心编程(多线程编程)
1.全局解释器锁 2.threading模块 thread类
- linux编程之多线程编程
我们知道,进程在各自独立的地址空间中运行,进程之间共享数据需要用mmap或者进程间通信机制,有些情况需要在一个进程中同时执行多个控制流程,这时候线程就派上了用场,比如实现一个图形界面的下载软件,一方面 ...
随机推荐
- winform窗体(五)——布局方式
一.默认布局 ★可以加panel,也可以不加: ★通过鼠标拖动控件的方式,根据自己的想法布局.拖动控件的过程中,会有对齐的线,方便操作: ★也可选中要布局的控件,在工具栏中有对齐工具可供选择,也有调整 ...
- 1. 什么是Docker?
##### 一.什么是Dokcer?> Docker是一个开源项目, 诞生于2013年初, 最初是dotCloud公司内部的一个业余项目. 它基于Google公司推出的Go语言实现. 项目后来加 ...
- nginx $document_uri 防止死循环
$document_uri 表示访问的url 现在我的需求是,访问 www.xxx.com 请求到 www.xxx.com/bbs/ 在nginx配置文件中加入 if ($document_uri ! ...
- [diango]批量导入不重复数据
去年研究导入数据的时候写了一个批量导入数据的脚本,但有个问题,如果导入这批数据在数据库中已经存在,那么我们导入的数据不就重复了么,本文就讨论如何解决这个问题? 程序如下: #coding:utf-8 ...
- J2EE基础之JavaBean
J2EE基础之JavaBean 1.什么是JavaBean? JavaBean本质上来说就是一个Java类,它通过封装属性和方法成为具有独立功能.可重复使用的,并可以与其他控件通信的组件对象.通过在J ...
- 兼容可控硅调光的一款LED驱动电路记录
1.该款电路为兼容可控硅调光的LED驱动电路,采用OB3332为开关控制IC,拓扑方案为Buck: 2.FB1:磁珠的单位是欧姆,而不是亨利,这一点要特别注意.因为磁珠的单位是按照它在某一频率 产生的 ...
- MyBlog
2016-06-25 一直想在搭建一个自己的blog.说来惭愧,cnblogs中的个人博客虽笔耕不辍,但杂乱无章.然而之前总是嘴上说说.现在,终于要行动起来了. 初步计划: 思路: django + ...
- PHP对文件数据的存储和检索
@(主要是对文件的操作) 文件处理:php操作文件主要是写入和读取这两种.执行的步骤都是一样的. 1.打开这个文件.如果打不开就先创建它.2.将数据写入这个文件,或者将数据读出这个文件.3.关闭文件. ...
- 上海闪酷成为京东商城第一批独立软件开发商(ISV)
闪酷信息技术(上海)有限公司一直致力于为品牌企业提供电子商务软件及其服务,为其拓展电商渠道保驾护航.上海闪酷依据多年的行业经验和技术积累,与中国 最大的B2C商城达成战略合作,为其2万多家品牌供应商提 ...
- PHP中使用CURL请求页面,使用fiddler进行抓包
在PHP中使用CURL访问页面: <?php $ch = curl_init('http://www.baidu.com'); curl_setopt($ch, CURLOPT_RETURNTR ...