我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python多线程以及多线程中join()的使用方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python多线程以及多线程中join()的使用方法

本篇内容主要讲解“Python多线程以及多线程中join()的使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python多线程以及多线程中join()的使用方法”吧!

Python多线程与多进程中join()方法的效果是相同的。

下面仅以多线程为例:

首先需要明确几个概念:

知识点一:

当一个进程启动之后,会默认产生一个主线程,因为线程是程序执行流的最小单元,当设置多线程时,主线程会创建多个子线程,在python中,默认情况下(其实就是setDaemon(False)),主线程执行完自己的任务以后,就退出了,此时子线程会继续执行自己的任务,直到自己的任务结束,

见下面 例子一。

知识点二:

当我们使用setDaemon(True)方法,设置子线程为守护线程时,主线程一旦执行结束,则全部线程全部被终止执行,可能出现的情况就是,子线程的任务还没有完全执行结束,就被迫停止,

见下面例子二。

知识点三:

此时join的作用就凸显出来了,join所完成的工作就是线程同步,即主线程任务在设置join函数的地方,进入阻塞状态,一直等待其他的子线程执行结束之后,主线程再开始执行直到终止终止,

例子见下面三。

知识点四:

join有一个timeout参数:

  • 当有设置守护线程时,含义是主线程对于子线程等待timeout的时间将会杀死该子线程,最后退出程序。所以说,如果有10个子线程,全部的等待时间就是每个timeout的累加和。简单的来说,就是给每个子线程一个timeout的时间,让他去执行,时间一到,不管任务有没有完成,直接杀死。

  • 没有设置守护线程时,主线程将会等待timeout的累加和这样的一段时间,时间一到,主线程结束,但是并没有杀死子线程,子线程依然可以继续执行,直到子线程全部结束,程序退出。

一:Python多线程的默认情况

import threadingimport timedef run():    time.sleep(2)    print('当前线程的名字是: ', threading.current_thread().name)    time.sleep(2)if __name__ == '__main__':    start_time = time.time()    print('这是主线程:', threading.current_thread().name)    thread_list = []    for i in range(5):        t = threading.Thread(target=run)        thread_list.append(t)    for t in thread_list:        t.start()    print('主线程结束!' , threading.current_thread().name)    print('一共用时:', time.time()-start_time)

其执行结果如下:

Python多线程以及多线程中join()的使用方法

关键:

  • 计时是对主线程计时,主线程结束,计时随之结束,打印出主线程的用时。

  • 主线程的任务完成之后,主线程随之结束,子线程继续执行自己的任务,直到全部的子线程的任务全部结束,程序结束。

二:设置守护线程

import threadingimport timedef run():    time.sleep(2)    print('当前线程的名字是: ', threading.current_thread().name)    time.sleep(2)if __name__ == '__main__':    start_time = time.time()    print('这是主线程:', threading.current_thread().name)    thread_list = []    for i in range(5):        t = threading.Thread(target=run)        thread_list.append(t)    for t in thread_list:        t.setDaemon(True)        t.start()    print('主线程结束了!' , threading.current_thread().name)    print('一共用时:', time.time()-start_time)

注意:注意请确保setDaemon()在start()之前

其执行结果如下:

Python多线程以及多线程中join()的使用方法

关键点:

非常明显的看到,主线程结束以后,子线程还没有来得及执行,整个程序就退出了。

三:join的作用

import threadingimport timedef run():    time.sleep(2)    print('当前线程的名字是: ', threading.current_thread().name)    time.sleep(2)if __name__ == '__main__':    start_time = time.time()    print('这是主线程:', threading.current_thread().name)    thread_list = []    for i in range(5):        t = threading.Thread(target=run)        thread_list.append(t)    for t in thread_list:        t.setDaemon(True)        t.start()    for t in thread_list:        t.join()    print('主线程结束了!' , threading.current_thread().name)    print('一共用时:', time.time()-start_time)

其执行结果如下:

Python多线程以及多线程中join()的使用方法

关键点:

可以看到,主线程一直等待全部的子线程结束之后,主线程自身才结束,程序退出。

主程序意外退出的情况

在线程A中使用B.join()表示线程A在调用join()处被阻塞,且要等待线程B的完成才能继续执行

import threadingimport timedef child_thread1():    for i in range(10):        time.sleep(1)        print('child_thread1_running...')def child_thread2():    for i in range(5):        time.sleep(1)        print('child_thread2_running...')def parent_thread():    print('parent_thread_running...')    thread1 = threading.Thread(target=child_thread1)    thread2 = threading.Thread(target=child_thread2)    thread1.setDaemon(True)    thread2.setDaemon(True)    thread1.start()    thread2.start()    thread2.join()    1/0    thread1.join()    print('parent_thread_exit...')if __name__ == "__main__":    parent_thread()

输出:

parent_thread_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
child_thread1_running...
child_thread2_running...
Traceback (most recent call last):
  File "E:/test_thread.py", line 31, in <module>
    parent_thread()
  File "E:/test_thread.py", line 25, in parent_thread
    1/0
ZeroDivisionError: integer division or modulo by zero

主线程在执行到thread2.join()时被阻塞,等待thread2结束后才会执行下一句

1/0会使主线程报错退出,且thread1设置了daemon=True,因此主线程意外退出时thread1也会立即结束。thread1.join()没有被主线程执行

到此,相信大家对“Python多线程以及多线程中join()的使用方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python多线程以及多线程中join()的使用方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python多线程以及多线程中join()的使用方法

本篇内容主要讲解“Python多线程以及多线程中join()的使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python多线程以及多线程中join()的使用方法”吧!Python多线程与
2023-06-20

join()方法如何在多线程中使用

今天就跟大家聊聊有关join()方法如何在多线程中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Thread中,join()方法的作用是调用线程等待该线程完成后,才能继续用下运行
2023-05-31

java多线程join方法怎么使用

在Java中,join()方法是Thread类的一个方法,用于等待该线程完成执行。当在一个线程中调用另一个线程的join()方法时,当前线程会被阻塞,直到被调用的线程执行完毕。join()方法有两种使用方式:1. join():调用该方法的
2023-08-11

python多线程线程锁的使用方法

小编给大家分享一下python多线程线程锁的使用方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!python的数据类型有哪些?python的数据类型:1. 数字
2023-06-14

怎么在python多线程中使用join

怎么在python多线程中使用join?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、
2023-06-14

JAVA多线程中join()方法怎么用

小编给大家分享一下JAVA多线程中join()方法怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!虽然关于讨论线程join()方法的博客已经非常极其特别多了,但是前几天我有一个困惑却没有能够得到详细解释,就是当系统中正
2023-06-15

python中多进程和多线程的使用方法

这篇文章主要介绍了python中多进程和多线程的使用方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。进程和线程进程是系统进行资源分配的最小单位,线程是系统进行调度执行的最小
2023-06-14

python的多线程中的join的作用

1 python 默认参数创建线程后,不管主线程是否执行完毕,都会等待子线程执行完毕才一起退出,有无join结果一样例子如下:import threadingimport timedef say(name): print('%s is
2023-01-31

线程以及多线程,多进程的选择

我的理解是进程是指在系统中正在运行的一个应用程序;程序一旦运行就是进程,或者更专业化来说:进程是指程序执行时的一个实例,线程是进程的一个实体。进程——资源分配的最小单位,线程——程序执行的最小单位。线程进程的区别体现在几个方面:
2023-06-04

python 多线程的使用

在实际编程过程中经常需要把任务包装成多进程或者多线程,多进程和多线程的区别在于多线程是内存共享、变量等共享的,多进程的进程间是独立运行的,所以创建多线程还是多进程取决于不同的需求。python中因为有全局锁的机制,所以在python中多线程
2023-01-31

Python中多线程的创建及基本调用方法

1. 多线程的作用 简而言之,多线程是并行处理相互独立的子任务,从而大幅度提高整个任务的效率。 2. Python中的多线程相关模块和方法 Python中提供几个用于多线程编程的模块,包括thread,threading和Queue等 th
2022-06-04

Python中多进程—Join方法使用、进程锁及进程间通信

本篇给大家介绍Python中多进程,Join方法使用、进程锁及进程间通信。
Python2024-12-03

一文带你掌握Python中多线程和线程池的使用方法

Python中的多线程和线程池是其强大的功能之一,可以让我们更加高效地利用CPU资源,提高程序的运行速度。本文将介绍Python中多线程和线程池的使用方法,并提供一些实用的案例供读者参考
2023-05-16

Java 中 join()方法在多线程同步方面究竟起到了何种作用?(java join()方法在多线程同步中的作用是什么)

在Java多线程编程中,join()方法是一个非常重要的用于线程同步的工具。它主要用于等待其他线程完成其任务,然后再继续当前线程的执行。一、join()方法的基本概念和语法join()
Java 中 join()方法在多线程同步方面究竟起到了何种作用?(java join()方法在多线程同步中的作用是什么)
Java2024-12-21

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录