博客
关于我
python笔记9-多线程Threading之阻塞(join)和守护线程(setDaemon)
阅读量:476 次
发布时间:2019-03-06

本文共 1612 字,大约阅读时间需要 5 分钟。

多线程应用实例

今天小编YOYO请小伙伴们吃火锅,吃完火锅时会出现三种不同的场景。这些场景不仅考验团队的默契,也为我们理解多线程编程提供了绝佳的实例。

1. 主线程与子线程

在编程中,主线程负责协调子线程的执行。以下场景展示了主线程与子线程的关系:

  • 场景一:主线程已结束,而子线程仍在运行。这种情况下,子线程可能会导致主线程无法正常退出。
  • 场景二:主线程结束后,子线程也随之终止。这通常通过设置主线程为守护线程来实现。

2. 守护线程setDaemon()

为了确保主线程退出时所有子线程也随之终止,我们可以使用setDaemon()方法将子线程设置为守护线程。这样一来,只要主线程退出,所有子线程都会自动终止。

  • 场景二:主线程结束后,子线程也会随之终止。这与设置守护线程的效果一致。

3. 阻塞主线程join(timeout)

如果需要让主线程等待子线程完成,可以使用join()方法。join(timeout)还允许设置超时,确保主线程不会无限等待。

  • 场景三:主线程等待子线程完成后,再一起结账走人。这与使用join()的效果一致。

4. 参考代码

以下代码展示了如何创建并管理多线程:

import threadingimport timedef 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.__init__(self)        self.threadName = name        self.people = people    def run(self):        print("开始线程: " + self.threadName)        chiHuoGuo(self.people)        print("qq交流群:226296743")        print("结束线程: " + self.name)print("yoyo请小伙伴开始吃火锅:!!!")# 创建新线程thread1 = myThread("xiaoming", "Thread-1")thread2 = myThread("xiaowang", "Thread-2")# 设置守护线程thread1.setDaemon(True)thread2.setDaemon(True)# 开启线程thread1.start()thread2.start()time.sleep(0.1)print("退出主线程:吃火锅结束,结账走人")

5. 运行结果

运行上述代码可以看到以下输出:

yoyo请小伙伴开始吃火锅:!!!开始线程:Thread-1开始线程:Thread-2吃火锅的小伙伴-羊肉:xiaoming吃火锅的小伙伴-鱼丸:xiaoming吃火锅的小伙伴-羊肉:xiaowang吃火锅的小伙伴-鱼丸:xiaowang结束线程:Thread-1结束线程:Thread-2退出主线程:吃火锅结束,结账走人

6. 注意事项

  • 设置守护线程:必须在start()之前调用setDaemon(True),否则程序可能会被无限挂起。
  • 使用join():如果需要确保子线程完成执行,可以使用join()方法。
  • 线程组管理:可以将多个线程组合在一起管理,使用join()等待所有线程完成。

通过上述实例,我们可以清晰地理解多线程编程的基本原理及其应用场景。希望这些内容能为您的学习提供帮助!

转载地址:http://bdmbz.baihongyu.com/

你可能感兴趣的文章
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>