- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Python3的多线程学习笔记
Python3的threading学习笔记
Python3的threading学习笔记
PPyytthhoonn33的的tthhrreeaaddiinngg学学习习笔笔记记
作者:罗寅兵 日期:2012-11-14
一、线程基础
一、线程基础
一一、、线线程程基基础础
1、线程状态
1、线程状态
11、、线线程程状状态态
启 动 调 度 结 束
新 建 就 绪 运 行 死 亡
解 除 阻 塞 满足阻塞条件
同 步 阻 塞 | 等 待 阻 塞 | I O 阻 塞
2、线程互斥锁同步控制
2、线程互斥锁同步控制
22、、线线程程互互斥斥锁锁同同步步控控制制
多个线程需要修改同一共享数据时,需要进行同步控制,引入了锁的概念。
访问共享数据
锁 定 池
请 求 锁 定
线 获 得 锁 定
程
访 问 完 成
锁 定
释 放 锁 定
a、同一时间可能有多个线程在锁定池中,它们处于同步阻塞状态竞争锁定;
b、同一时间只能有一个线程获得锁定处于运行状态。
3、条件变量(线程通信)
3、条件变量(线程通信)
33、、条条件件变变量量((线线程程通通信信))
有的线程需要预备条件才能干活。
访问共享数据 收 到 通 知
需 锁 定 池 请 求 锁 定
要 请 求 锁 定
条 获 得 锁 定
件 等 待 池
的
线 访 问 完 成
锁 定 条 件 不 足
程
释 放 锁 定 等 待 通 知
访问共享数据
创 锁 定 池
造 请 求 锁 定
条 获 得 锁 定 等 待 池
件
的
线 访 问 完 成 创 造 条 件
锁 定
程 发 送 通 知
释 放 锁 定
二、threading:线程创建、启动、睡眠、退出
二、threading:线程创建、启动、睡眠、退出
二二、、tthhrreeaaddiinngg::线线程程创创建建、、启启动动、、睡睡眠眠、、退退出出
1、方法一:将要执行的函数作为参数传递给threading.Thread()
1、方法一:将要执行的函数作为参数传递给threading.Thre
文档评论(0)