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获取当前时间的方法
Jan 14 Python
Python中super关键字用法实例分析
May 28 Python
Django实现的自定义访问日志模块示例
Jun 23 Python
目前最全的python的就业方向
Jun 05 Python
django orm 通过related_name反向查询的方法
Dec 15 Python
把django中admin后台界面的英文修改为中文显示的方法
Jul 26 Python
django 做 migrate 时 表已存在的处理方法
Aug 31 Python
ubuntu上安装python的实例方法
Sep 30 Python
PyTorch实现更新部分网络,其他不更新
Dec 31 Python
Python 使用双重循环打印图形菱形操作
Aug 09 Python
python如何控制进程或者线程的个数
Oct 16 Python
python元组打包和解包过程详解
Aug 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
第四节 构造函数和析构函数 [4]
2006/10/09 PHP
ThinkPHP基本的增删查改操作实例教程
2014/08/22 PHP
PHP缓存集成库phpFastCache用法
2014/12/15 PHP
ecshop 2.72如何修改后台访问地址
2015/03/03 PHP
php base64 编码与解码实例代码
2017/03/21 PHP
Javascript的一种模块模式
2010/09/08 Javascript
基于mootools 1.3框架下的图片滑动效果代码
2011/04/22 Javascript
js自动闭合html标签(自动补全html标记)
2012/10/04 Javascript
js 判断一个元素是否在页面中存在
2012/12/27 Javascript
关于jquery input textare 事件绑定及用法学习
2013/04/03 Javascript
json数据的列循环示例
2013/09/06 Javascript
jquery 提示信息显示后自动消失的具体实现
2013/12/18 Javascript
jquery ajax 局部刷新小案例
2014/02/08 Javascript
使用js实现关闭js弹出层的窗口
2014/02/10 Javascript
JavaScript数组对象赋值用法实例
2015/08/04 Javascript
详解jQuery中的deferred对象的使用(一)
2016/05/27 Javascript
JavaScript中值类型和引用类型的区别
2017/02/23 Javascript
webpack教程之webpack.config.js配置文件
2017/07/05 Javascript
利用require.js与angular搭建spa应用的方法实例
2017/07/19 Javascript
详解vuex中mapState,mapGetters,mapMutations,mapActions的作用
2018/04/13 Javascript
[48:39]Ti4主赛事胜者组第一天 EG vs NEWBEE 2
2014/07/19 DOTA
python处理文本文件实现生成指定格式文件的方法
2014/07/31 Python
Python绘制正余弦函数图像的方法
2018/08/28 Python
python2.7的flask框架之引用js&css等静态文件的实现方法
2019/08/22 Python
python中property属性的介绍及其应用详解
2019/08/29 Python
基于pytorch的lstm参数使用详解
2020/01/14 Python
解决pycharm同一目录下无法import其他文件
2020/02/12 Python
Vans荷兰官方网站:美国南加州的原创极限运动潮牌
2018/01/23 全球购物
拥有超过850家商店的美国在线派对商店:Party City
2018/10/21 全球购物
一些Unix笔试题和面试题
2013/01/22 面试题
高中生学习生活的自我评价
2013/10/09 职场文书
财务方面个人工作的自我评价
2013/12/28 职场文书
买房委托公证书
2014/04/08 职场文书
2014年教研组工作总结
2014/11/26 职场文书
安全教育培训制度
2015/08/06 职场文书
python热力图实现的完整实例
2022/06/25 Python