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

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

多线程应用实例

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

1. 主线程与子线程

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

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

2. 守护线程setDaemon()

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

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

3. 阻塞主线程join(timeout)

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

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

4. 参考代码

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

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):
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/

你可能感兴趣的文章
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>