博客
关于我
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 基础架构
查看>>
MySQL 基础模块的面试题总结
查看>>
MySQL 处理插入重主键唯一键重复值办法
查看>>
MySQL 备份 Xtrabackup
查看>>
mysql 复杂查询_mysql中复杂查询
查看>>
mYSQL 外键约束
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>