设为首页 收藏本站
查看: 997|回复: 0

[经验分享] python多线程编程(1): python对多线程的支持

[复制链接]

尚未签到

发表于 2015-4-20 08:52:32 | 显示全部楼层 |阅读模式
  前面介绍过多线程的基本概念,理解了这些基本概念,掌握python多线程编程就比较容易了。
  在开始之前,首先要了解一下python对多线程的支持。
虚拟机层面
  Python虚拟机使用GIL(Global Interpreter Lock,全局解释器锁)来互斥线程对共享资源的访问,暂时无法利用多处理器的优势。
语言层面
  在语言层面,Python对多线程提供了很好的支持,Python中多线程相关的模块包括:thread,threading,Queue。可以方便地支持创建线程、互斥锁、信号量、同步等特性。
  thread:多线程的底层支持模块,一般不建议使用。
  threading:对thread进行了封装,将一些线程的操作对象化,提供下列类:
  Thread 线程类
  Timer与Thread类似,但要等待一段时间后才开始运行
  Lock 锁原语
  RLock 可重入锁。使单线程可以再次获得已经获得的锁
  Condition 条件变量,能让一个线程停下来,等待其他线程满足某个“条件”
  Event 通用的条件变量。多个线程可以等待某个事件发生,在事件发生后,所有的线程都被激活
  Semaphore为等待锁的线程提供一个类似“等候室”的结构
  BoundedSemaphore 与semaphore类似,但不允许超过初始值
  Queue:实现了多生产者(Producer)、多消费者(Consumer)的队列,支持锁原语,能够在多个线程之间提供很好的同步支持。提供的类:
  Queue队列
  LifoQueue后入先出(LIFO)队列
  PriorityQueue 优先队列
  
  其中Thread类是你主要的线程类,可以创建进程实例。该类提供的函数包括:
  getName(self) 返回线程的名字
  isAlive(self) 布尔标志,表示这个线程是否还在运行中
  isDaemon(self) 返回线程的daemon标志
  join(self, timeout=None) 程序挂起,直到线程结束,如果给出timeout,则最多阻塞timeout秒
  run(self) 定义线程的功能函数
  setDaemon(self, daemonic)  把线程的daemon标志设为daemonic
  setName(self, name) 设置线程的名字
  start(self) 开始线程执行
  
第三方支持
  如果你特别在意性能,还可以考虑一些“微线程”的实现:
  Stackless Python:Python的一个增强版本,提供了对微线程的支持。微线程是轻量级的线程,在多个线程间切换所需的时间更多,占用资源也更少。
  greenlet:是 Stackless 的副产品,其将微线程称为 “tasklet” 。tasklet运行在伪并发中,使用channel进行同步数据交换。而”greenlet”是更加原始的微线程的概念,没有调度。你可以自己构造微线程的调度器,也可以使用greenlet实现高级的控制流。
  下一节,将开始用python创建和启动线程。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-58642-1-1.html 上篇帖子: Python标准库05 存储对象 (pickle包,cPickle包) 下篇帖子: python基础学习笔记(八)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表