一篇文章带你全面解析不一样的线程.docxVIP

一篇文章带你全面解析不一样的线程.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一篇文章带你全面解析不一样的线程 在将今日的学问点之前,大家能否了解线程,进程和协程了,那我们先来初步了解下吧。 线程 中心处理器的调度单元,简约点说就是程序中的末端执行者,相当于小弟的位置。 有人说python中的线程是个鸡肋,这是由于有了GIL,但是又不是一味的鸡肋,到底在执行io操作时还是挺管用的,只是在执行计算时就显得不尽人意。下面我们来看下线程的具体使用方法: 1.导入线程模块: import threading as t 2.线程的用法 tt=t.Thread(group=None,target=None,name=None,args=(),kwargs={},name=,daemon=None) group:线程组,必需是None target:运转的函数 args:传入函数的参数元组 kwargs:传入函数的参数字典 name:线程名 daemon:线程能否随主线程退出而退出(守护线程) Thread方法的前往值还有以下方法: tt.start() : 激活线程, tt.getName() : 猎取线程的名称 tt.setName() :设置线程的名称 tt.name : 猎取或设置线程的名称 tt.is_alive() :推断线程能否为激活形态 tt.isAlive() :推断线程能否为激活形态 tt.setDaemon() 设置为守护线程(默认:False) tt.isDaemon() :推断能否为守护线程 tt.ident :猎取线程的标识符。只要在调用了start()方法之后该属性才有效 tt.join() :逐一执行每个线程,执行完毕后连续往下执行 tt.run() :自动执行线程对象 t的方法也有: t.active_count(): 前往正在运转线程的数量 t.enumerate(): 前往正在运转线程的列表 t.current_thread().getName() 猎取当前线程的名字 t.TIMEOUT_MAX 设置t的全局超时时间 下面我们来看下吧: 3.创建线程 线程可以使用Thread方法创建,也可以重写线程类的run方法实现,线程可分为单线程和多线程。 一、使用Thread方法来创建: 1.单线程 def xc(): for y in range(100): print(运转中+str(y)) tt=t.Thread(target=xc,args=()) #方法加入到线程 tt.start() #开头线程 tt.join() #等待子线程结束 2.多线程 def xc(num): print(运转:+str(num)) c=[] for y in range(100): tt=t.Thread(target=xc,args=(y,)) tt.start() #开头线程 c.append(tt) #创建列表并添加线程 for x in c: x.join() #等待子线程结束 二、重写线程的类方法 1.单线程 class Xc(t.Thread): #承继Thread类 def __init__(self): super(Xc, self).__init__() def run(self): #重写run方法 for y in range(100): print(运转中+str(y)) x=Xc() x.start() #开头线程 x.join() #等待子线程结束 也可以这么写: Xc().run() 和上面的效果是一样的 2.多线程 class Xc(t.Thread): #承继Thread类 def __init__(self): super(Xc, self).__init__() def run(self,num): #重写run方法 print(运转:+str(num)) x=Xc() for y in range(10): x.run(y) #运转 4.线程锁 为什么要加锁,看了这个你就晓得了: 多线程在运转时同时访问一个对象会产生抢占资源的情况,所以我们必需得束缚它,所以就要给他加一把锁把他锁住,这就是同步锁。要了解锁,我们得先创建锁,线程中有两种锁:Lock和RLock。 一、Lock 使用方法: # 猎取锁 当猎取不到锁时,默认进入堵塞形态,设置超时时间,直到猎取到锁,后才连续。非堵塞时,timeout禁止设置。假如超时照旧未猎取到锁,前往False。 Lock.acquire(blocking=True,timeout=1) #释放锁,已上锁的锁,会被设置

文档评论(0)

bob157641554 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档