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 Django模板的使用方法(图文)
Nov 04 Python
python实现进程间通信简单实例
Jul 23 Python
python字符串连接方式汇总
Aug 21 Python
Python处理RSS、ATOM模块FEEDPARSER介绍
Feb 18 Python
Python计算三维矢量幅度的方法
Jun 15 Python
解决Scrapy安装错误:Microsoft Visual C++ 14.0 is required...
Oct 01 Python
pip matplotlib报错equired packages can not be built解决
Jan 06 Python
pycharm 将python文件打包为exe格式的方法
Jan 16 Python
谈谈Python中的while循环语句
Mar 10 Python
Django基础知识 URL路由系统详解
Jul 18 Python
pytorch nn.Conv2d()中的padding以及输出大小方式
Jan 10 Python
Python matplotlib可视化之绘制韦恩图
Feb 24 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中函数内引用全局变量的方法
2008/10/20 PHP
通过php快速统计某个数据库中每张表的数据量
2012/09/04 PHP
PHP中iconv函数转码时截断字符问题的解决方法
2015/01/21 PHP
php随机生成数字字母组合的方法
2015/03/18 PHP
Aster vs Newbee BO5 第二场2.19
2021/03/10 DOTA
document.getElementById方法在Firefox与IE中的区别
2010/05/18 Javascript
jQuery绑定事件不执行但alert后可以正常执行
2014/06/03 Javascript
Backbone.js中的集合详解
2015/01/14 Javascript
JS函数的定义与调用方法推荐
2016/05/12 Javascript
Nodejs 搭建简单的Web服务器详解及实例
2016/11/30 NodeJs
jQuery实现页面滚动时智能浮动定位
2017/01/08 Javascript
BootStrap实现鼠标悬停下拉列表功能
2017/02/17 Javascript
javascript使用btoa和atob来进行Base64转码和解码
2017/03/20 Javascript
jQuery插件imgAreaSelect基础讲解
2017/05/26 jQuery
nodejs爬虫初试superagent和cheerio
2018/03/05 NodeJs
200行代码实现blockchain 区块链实例详解
2018/03/14 Javascript
详解从Vue-router到html5的pushState
2018/07/21 Javascript
layui的table中显示图片方法
2018/08/17 Javascript
node.js调用C++函数的方法示例
2018/09/21 Javascript
element-ui中dialog弹窗关闭按钮失效的解决
2020/09/22 Javascript
详解Python之数据序列化(json、pickle、shelve)
2017/03/30 Python
Django contenttypes 框架详解(小结)
2018/08/13 Python
详解基于python-django框架的支付宝支付案例
2019/09/23 Python
PyTorch 解决Dataset和Dataloader遇到的问题
2020/01/08 Python
如何写一份好的自荐信
2014/01/02 职场文书
建议书的格式
2014/05/12 职场文书
机电一体化专业求职信
2014/07/22 职场文书
教师作风整改措施思想汇报
2014/10/12 职场文书
2014司机年终工作总结
2014/12/05 职场文书
老兵退伍感言
2015/08/03 职场文书
创业计划书之烤红薯
2019/09/26 职场文书
python opencv常用图形绘制方法(线段、矩形、圆形、椭圆、文本)
2021/04/12 Python
react中props 的使用及进行限制的方法
2021/04/28 Javascript
python使用BeautifulSoup 解析HTML
2022/04/24 Python
阿里云服务器Ubuntu 20.04上安装Odoo 15
2022/05/20 Servers
JavaScript设计模式之原型模式详情
2022/06/21 Javascript