博客
关于我
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互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
MySQL 内核深度优化
查看>>
mysql 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>