• python笔记9-多线程Threading之阻塞(join)和守护线程(setDaemon)


    前言

    今天小王请xiaoming和xiaowang吃火锅,吃完火锅的时候会有以下三种场景:

    • 场景一:小王(主)先吃完了,海海(客)和老王(客)还没吃完,这种场景会导致结账的人先走了,剩下两个小伙伴傻眼了。。。

    • 场景二:小王(主)先吃完了,海海和老王还没吃饱,一起结账走人。

    • 场景三:小王(主)先等海海和老王吃饱了,小编最后结账一起走人。

    主线程与子线程

    场景一:主线程已经结束了,子线程还在跑

    1.我们把thread1.start()和thread2.start()称为两个子线程,写在外面的代码就是主线程了。



    # -*- coding:utf-8 -*-
    import time
    import threading

    def chiHuoGuo(people):
    print("%s 吃火锅的小伙伴-羊肉:%s" % (time.ctime(),people))
    time.sleep(1)
    print("%s 吃火锅的小伙伴-鱼丸:%s" % (time.ctime(),people))

    class myThread(threading.Thread):
    def __init__(self, people, name):
    '''重写threading.Thread初始化内容'''
    threading.Thread.__init__(self)
    self.threadNmae = name
    self.people = people

    def run(self):
    print("开始线程:" + self.threadNmae)

    chiHuoGuo(self.people)
    print("结束线程:" + self.threadNmae)

    if __name__ == "__main__":
    # 启动线程
    thread1 = myThread("xiaoming", "Thread-1")
    thread2 = myThread("xiaowang", "Thread-2")

    thread1.start()
    thread2.start()

    time.sleep(0.1)
    print("退出主线程:吃火锅,结账走人")

    守护线程setDaemon()

    场景二:主线程结束了,子线程必须也跟着结束

    1.主线程中,创建了子线程 线程A和线程B,并且在主线程中调用了thread.setDaemon(),这个的意思是,把主线程设置为守护线程,这时候,要是主线程执行结束了,就不管子线程是否完成,一并和主线程退出.
    (敲黑板:必须在start()方法调用之前设置,如果不设置为守护线程,程序会被无限挂起。)

    2.线程有一个布尔属性叫做daemon。表示线程是否是守护线程,默认取否。当程序中的线程全部是守护线程时,程序才会退出。只要还存在一个非守护线程,程序就不会退出。
    主线程是非守护线程。

    3.setDaemon(True)此方法里面参数设置为True才会生效

    # coding=utf-8
    import threading
    import time
    
    def chiHuoGuo(people):
        print("%s 吃火锅的小伙伴-羊肉:%s" % (time.ctime(),people))
        time.sleep(1)
        print("%s 吃火锅的小伙伴-鱼丸:%s" % (time.ctime(),people))
    
    
    class myThread (threading.Thread):   # 继承父类threading.Thread
        def __init__(self, people, name):
            '''重写threading.Thread初始化内容'''
            threading.Thread.__init__(self)
            self.threadName = name
            self.people = people
    
        def run(self):   # 把要执行的代码写到run函数里面 线程在创建后会直接运行run函数
            '''重写run方法'''
            print("开始线程: " + self.threadName)
    
            chiHuoGuo(self.people)     # 执行任务
            
            print("结束线程: " + self.name)
    
    print("yoyo请小伙伴开始吃火锅:!!!")
    
    # 创建新线程
    thread1 = myThread("xiaoming", "Thread-1")
    thread2 = myThread("xiaowang", "Thread-2")
    
    # 守护线程setDaemon(True)
    thread1.setDaemon(True)       # 必须在start之前
    thread2.setDaemon(True)
    
    # 开启线程
    thread1.start()
    thread2.start()
    
    time.sleep(0.1)
    print("退出主线程:吃火锅结束,结账走人")
    

    4.运行结果:

    阻塞主线程join(timeout)

    1.如果想让主线程等待子线程结束后再运行的话,就需要用到join(),此方法是在start之后(与setDaemon相反)

    2.join(timeout)此方法有个timeout参数,是线程超时时间设置。

    # coding=utf-8
    import threading
    import time
    
    def chiHuoGuo(people):
        print("%s 吃火锅的小伙伴-羊肉:%s" % (time.ctime(),people))
        time.sleep(1)
        print("%s 吃火锅的小伙伴-鱼丸:%s" % (time.ctime(),people))
    
    
    class myThread (threading.Thread):   # 继承父类threading.Thread
        def __init__(self, people, name):
            '''重写threading.Thread初始化内容'''
            threading.Thread.__init__(self)
            self.threadName = name
            self.people = people
    
        def run(self):   # 把要执行的代码写到run函数里面 线程在创建后会直接运行run函数
            '''重写run方法'''
            print("开始线程: " + self.threadName)
    
            chiHuoGuo(self.people)     # 执行任务
            
            print("结束线程: " + self.name)
    
    print("yoyo请小伙伴开始吃火锅:!!!")
    
    # 创建新线程
    thread1 = myThread("xiaoming", "Thread-1")
    thread2 = myThread("xiaowang", "Thread-2")
    
    # 开启线程
    thread1.start()
    thread2.start()
    
    # 阻塞主线程,等子线程结束
    thread1.join()
    thread2.join()
    
    time.sleep(0.1)
    print("退出主线程:吃火锅结束,结账走人")

    运行结果:

     

  • 相关阅读:
    服务器的Redis连接不上解决方案
    给大家推荐一个很好的自学网站
    简单说下HashMap的实现原理
    LinkedList源码解析
    你要了解的jvm
    单例设计
    百度编辑器删除旧的图片
    Ueditor 单图、多图、视频、附件的上传及在线管理总结
    上传新图片删除旧图片
    webapi发布IIS时出现500.19错误:不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认设置的(overrideModeDefault="Deny")或者是通过包含overrideModeDefault="Deny"....
  • 原文地址:https://www.cnblogs.com/wanghaihong200/p/8617657.html
Copyright © 2020-2023  润新知