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中lambda函数 list comprehension 和 zip函数使用指南
Sep 28 Python
在Python的Bottle框架中使用微信API的示例
Apr 23 Python
使用python进行文本预处理和提取特征的实例
Jun 05 Python
python之文件读取一行一行的方法
Jul 12 Python
selenium使用chrome浏览器测试(附chromedriver与chrome的对应关系表)
Nov 29 Python
对python 多个分隔符split 的实例详解
Dec 20 Python
Python设计模式之备忘录模式原理与用法详解
Jan 15 Python
pandas DataFrame索引行列的实现
Jun 04 Python
python实现字符串完美拆分split()的方法
Jul 16 Python
解决Python3.8运行tornado项目报NotImplementedError错误
Sep 02 Python
Python如何利用Har文件进行遍历指定字典替换提交的数据详解
Nov 05 Python
pip install命令安装扩展库整理
Mar 02 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 上一篇,下一篇文章实现代码与原理说明
2010/05/09 PHP
PHP 截取字符串专题集合
2010/08/19 PHP
PHP笔记之:日期函数的使用介绍
2013/04/24 PHP
Symfony2实现在doctrine中内置数据的方法
2016/02/05 PHP
基于php双引号中访问数组元素报错的解决方法
2018/02/01 PHP
PHP7创建销毁session的实例方法
2020/02/03 PHP
关于event.cancelBubble和event.stopPropagation()的区别介绍
2011/12/11 Javascript
jQuery中$this和$(this)的区别介绍(一看就懂)
2015/07/06 Javascript
jQuery获取父元素及父节点的方法小结
2016/04/14 Javascript
微信小程序 教程之引用
2016/10/18 Javascript
Bootstrap导航条鼠标悬停下拉菜单
2017/01/04 Javascript
localStorage的黑科技-js和css缓存机制
2017/02/06 Javascript
jQuery实现Select下拉列表进行状态选择功能
2017/03/30 jQuery
微信小程序 监听手势滑动切换页面实例详解
2017/06/15 Javascript
JS解决position:sticky的兼容性问题的方法
2017/10/17 Javascript
node.js中路由,中间件,ge请求和post请求的参数详解
2017/12/26 Javascript
改变vue请求过来的数据中的某一项值的方法(详解)
2018/03/08 Javascript
js数组去重的N种方法(小结)
2018/06/07 Javascript
vue获取时间戳转换为日期格式代码实例
2019/04/17 Javascript
[02:15]你好,这就是DOTA!
2015/08/05 DOTA
Python程序中使用SQLAlchemy时出现乱码的解决方案
2015/04/24 Python
在Python中使用HTMLParser解析HTML的教程
2015/04/29 Python
Python装饰器知识点补充
2018/05/28 Python
python实现输入任意一个大写字母生成金字塔的示例
2019/10/27 Python
Tensorflow中的降维函数tf.reduce_*使用总结
2020/04/20 Python
Python面向对象特殊属性及方法解析
2020/09/16 Python
豆腐の盛田屋官网:日本自然派的豆乳面膜、肥皂、化妆水、乳液等
2016/10/08 全球购物
印度服装购物网站:Limeroad
2018/09/26 全球购物
表彰会主持词
2014/03/26 职场文书
国庆节活动总结
2014/08/26 职场文书
群众路线教育实践活动学习笔记
2014/11/05 职场文书
2015教师年度考核评语
2015/03/25 职场文书
2016元旦晚会主持词开场白和结束语
2015/12/04 职场文书
实习报告怎么写
2019/06/20 职场文书
关于企业的执行力标语大全
2020/01/06 职场文书
Redis 哨兵机制及配置实现
2022/03/25 Redis