Python多线程Threading、子线程与守护线程实例详解


Posted in Python onMarch 24, 2020

本文实例讲述了Python多线程Threading、子线程与守护线程。分享给大家供大家参考,具体如下:

线程与进程:

  • 线程对于进程来说,就好似工厂里的工人,分配资源是分配到工厂,工人再去处理。
  • 线程是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。
  • 在单个程序中同时运行多个线程完成不同的工作,称为多线程
  • 对于IO密集型的程序来说,多线程可以利用读IO的时间去做其他事【IO并不占用CPU,这就好像A买个一份外卖,他只需要等着送过来然后敲A家的门就行了】;
  • 而对于CPU密集型的程序来说,多线程的效率就不是很高了【CPU由于要计算,切换之间要恢复之前的现场消耗相对较大,比如我同时做几份作业,一份作业做十分钟,假如十分钟做不完一份作业,那么我后面再回头做的时候,我就要好好想想刚才做到哪,刚才想到哪

    补充:IO需要CPU吗?知乎:https://www.zhihu.com/question/27734728

    Python多线程Threading、子线程与守护线程实例详解


  • 线程Threading:

    python中多线程需要使用threading模块

    线程的创建与运行:

    1.直接调用threading的Thread类:

    线程的创建:线程对象=thread.Thread(target=函数名,args=(参数))【补充,由于args是一个元组,单个参数时要加“,”】

    线程的启动:线程对象.start(),调用start(),那么线程对象会自动去调用thread.Thread中的run()

    让主线程等待其余线程结束:线程对象.join(),加了join之后,相当于阻塞了主线程,主线程只有当join的线程结束后才会向下执行

    import threading,time
    
    def run(n):
     time.sleep(1)
     print("task ",n)
    
    t1=threading.Thread(target=run,args=("t1",))
    t2 = threading.Thread(target=run,args=("t2",))
    
    start_time=time.time()#开始时间
    t1.start()
    t2.start()
    ##因为是独立线程,如果想要主线程等待其他线程运行完毕,需要使用join
    t1.join()
    t2.join()
    spend_time=time.time()-start_time
    print(spend_time)##1.0多,说明是并行的结果

    附加说明--join是阻塞等待:

    import threading,time
    
    class MyTread(threading.Thread):
     def __init__(self,name):
      super(MyTread,self).__init__()#调用父类的__init__()
      self.name=name
     def run(self):#重写方法,按自己的要求去写
      time.sleep(1)
      print("run in task",self.name,threading.current_thread(),threading.active_count())
    
    t1=MyTread("t1")
    t2=MyTread("t2")
    start_time=time.time()
    t1.start()
    t2.start()
    
    t1.join()
    t2.join()
    time.sleep(1)###主线程等待其余线程结束
    print(time.time()-start_time)
    #结果是2.0多,证明是join是相当于阻塞了主线程的执行,只有当线程结束后才会向下执行

    2.继承threading的Thread类:

    继承threading的Thread类的类要主要做两件事:

    1.如果不做自定义变量的初始化,那么可以直接使用继承的父类的__init__(),如果需要做自定义变量的初始化,则需要先调用父类的__init__()【否则需要自己填写线程初始化相关的参数】

    2.重写run,虽然继承了父类的run,但实际上如果不重写,那么我们继承threading的Thread类又有什么意义呢?为什么不直接调用threading的Thread类

  • import threading,time
    
    class MyTread(threading.Thread):
     def __init__(self,name):
      super(MyTread,self).__init__()#调用父类的__init__()
      self.name=name
     def run(self):#重写方法,按自己的要求去写
      time.sleep(1)
      print("run in task",self.name,threading.current_thread(),threading.active_count())
    
    t1=MyTread("t1")
    t2=MyTread("t2")
    start_time=time.time()
    t1.start()
    t2.start()
    ###主线程等待其余线程结束
    t1.join()
    t2.join()
    print(time.time()-start_time)#结果是1.0多,证明是并行的

    子线程:

    • 由一个线程启动的线程可以成为它的子线程,A启动B,B是A的子线程,A是B的父线程

    线程的几个常用函数:

    • threading.current_thread():
    返回当前正在运行的线程对象
    
      
    • threading.active_count():
    返回当前进程中的存活的线程对象数

    Python多线程Threading、子线程与守护线程实例详解

    • 线程对象.isAlive()方法判断线程是否存活

    Python多线程Threading、子线程与守护线程实例详解

    • getName(): 返回线程名。
    • setName(): 设置线程名。

    Python多线程Threading、子线程与守护线程实例详解

  • get_ident():获取当前线程ID。


    守护线程:

    • 守护线程是起到辅助功能的,就好像魔法师放禁咒总要骑士保护一样【魔法师只需要关系自己的任务,保护他的任务交给守护者】
    • 而守护线程与主线程的关系呢,就好像备胎跟女神,去买东西的话,备胎要一直在外面等女神【守护线程运行结束就狗带,但不影响主进程结束,由主线程决定运行时间】,女神不需要等待备胎【主线程结束,守护线程也要结束,不管自身任务是否完成】
    • 与join的区别:join是阻塞等待,守护线程是并行的等待
    • 设置守护线程:线程对象.setDaemon(True)【注意!!!!!设置守护线程必须要在start()前面,不然会报错】

    下面的代码显示了主线程并不会等待其守护线程结束:

    import threading,time
    
    class MyTread(threading.Thread):
    
     def __init__(self,name):
      super(MyTread,self).__init__()
      self.name=name
     def run(self):
      print("守护线程已经启动",self.name)
      time.sleep(1)
      print("run in task",self.name,threading.current_thread(),threading.active_count())
    
    t1=MyTread("t1")
    t1.setDaemon(True)
    t2=MyTread("t2")
    t2.setDaemon(True)
    start_time=time.time()#开始时间
    t1.start()
    t2.start()
    
    spend_time=time.time()-start_time
    print(spend_time)##0.0多,而且三个线程都执行完毕了,说明这个是并行的等待

    Python多线程Threading、子线程与守护线程实例详解

    让主线程sleep一下,显示一下如果主线程要等待守护线程,那么是并行的等待:

    import threading,time
    
    class MyTread(threading.Thread):
    
     def __init__(self,name):
      super(MyTread,self).__init__()
      self.name=name
     def run(self):
      print("守护线程已经启动",self.name)
      time.sleep(1)
      print("run in task",self.name,threading.current_thread(),threading.active_count())
    
    t1=MyTread("t1")
    t1.setDaemon(True)
    t2=MyTread("t2")
    t2.setDaemon(True)
    start_time=time.time()#开始时间
    t1.start()
    t2.start()
    time.sleep(2)
    spend_time=time.time()-start_time
    print(spend_time)##2.0多,而且三个线程都执行完毕了,说明这个是并行的等待

    Python多线程Threading、子线程与守护线程实例详解

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
python k-近邻算法实例分享
Jun 11 Python
TF-IDF算法解析与Python实现方法详解
Nov 16 Python
python实现kNN算法
Dec 20 Python
Django ManyToManyField 跨越中间表查询的方法
Dec 18 Python
使用python获取(宜宾市地震信息)地震信息
Jun 20 Python
python增加图像对比度的方法
Jul 12 Python
python连接、操作mongodb数据库的方法实例详解
Sep 11 Python
Pytorch之Variable的用法
Dec 31 Python
pytorch实现对输入超过三通道的数据进行训练
Jan 15 Python
浅谈SciPy中的optimize.minimize实现受限优化问题
Feb 29 Python
python正则表达式 匹配反斜杠的操作方法
Aug 07 Python
Appium+Python实现简单的自动化登录测试的实现
Jan 26 Python
PYQT5 vscode联合操作qtdesigner的方法
Mar 24 #Python
ubuntu 安装pyqt5和卸载pyQt5的方法
Mar 24 #Python
Python socket连接中的粘包、精确传输问题实例分析
Mar 24 #Python
Pyqt5 关于流式布局和滚动条的综合使用示例代码
Mar 24 #Python
Python+Appium实现自动化测试的使用步骤
Mar 24 #Python
Python3标准库之dbm UNIX键-值数据库问题
Mar 24 #Python
python网络编程socket实现服务端、客户端操作详解
Mar 24 #Python
You might like
兼容PHP和Java的des加密解密代码分享
2014/06/26 PHP
浅谈PHP发送HTTP请求的几种方式
2017/07/25 PHP
学习thinkphp5.0验证类使用方法
2017/11/16 PHP
一款JavaScript压缩工具:X2JSCompactor
2007/06/13 Javascript
js使用数组判断提交数据是否存在相同数据
2013/11/27 Javascript
浅谈nodeName,nodeValue,nodeType,typeof 的区别
2015/01/13 Javascript
原生的强大DOM选择器querySelector介绍
2016/12/21 Javascript
基于vue-cli创建的项目的目录结构及说明介绍
2017/11/23 Javascript
关于vue中watch检测到不到对象属性的变化的解决方法
2018/02/08 Javascript
解决vue build打包之后首页白屏的问题
2018/03/06 Javascript
vue select组件的使用与禁用实现代码
2018/04/10 Javascript
webpack分离css单独打包的方法
2018/06/12 Javascript
详解Angular模板引用变量及其作用域
2018/11/23 Javascript
vue项目强制清除页面缓存的例子
2019/11/06 Javascript
python实现简单socket通信的方法
2016/04/19 Python
Python正则捕获操作示例
2017/08/19 Python
matplotlib简介,安装和简单实例代码
2017/12/26 Python
flask框架视图函数用法示例
2018/07/19 Python
Python3.5实现的三级菜单功能示例
2019/03/25 Python
python 将有序数组转换为二叉树的方法
2019/03/26 Python
纯python进行矩阵的相乘运算的方法示例
2019/07/17 Python
使用python-opencv读取视频,计算视频总帧数及FPS的实现
2019/12/10 Python
Python基础之列表常见操作经典实例详解
2020/02/26 Python
JavaScript+Canvas实现自定义画板的示例代码
2019/05/13 HTML / CSS
如何使用amaze ui的分页样式封装一个通用的JS分页控件
2020/08/21 HTML / CSS
洛杉矶健身中心女性专用运动服饰品牌:Marika
2018/05/09 全球购物
六一儿童节活动总结
2014/08/27 职场文书
项目合作协议书
2014/09/23 职场文书
买房子个人收入证明
2014/10/12 职场文书
2014年单位法制宣传日活动总结
2014/11/01 职场文书
2015年小学中秋节活动总结
2015/03/23 职场文书
追悼词范文大全
2015/06/23 职场文书
撤回我也能看到!教你用Python制作微信防撤回脚本
2021/06/11 Python
POST提交数据常见的四种方式
2022/01/18 HTML / CSS
Oracle用户管理及赋权
2022/04/24 Oracle
Java存储没有重复元素的数组
2022/04/29 Java/Android