编程小白的自学笔记八(python中的多线程)

简介: 编程小白的自学笔记八(python中的多线程)

前言

Python 多线程是指在一个进程中同时执行多个线程,从而实现并发执行。对于初学者来说,理解起来有难度,我们先来看看怎么用吧,先熟悉,后期在实际中再掌握。


一、创建线程

进程大家都知道,一般打开任务管理器,一个程序对应一个进程,当然也有一个程序对应好几个进程的,线程是比进程更小的单位,比如把抖音看作一个进程,视频播放是一个线程,同时还可以打赏和评论,打赏是一个线程,评论是一个线程。这些线程是可以同时进行的,至少看起来是这样。


在python中,多线程只允许同一时刻只有一个线程在执行,多个线程交替运行,看起来就好像同时在运行一样,这就是并发。下面我们用代码来模拟下:

import threading
def test(x,y):
    for i in range(x,y):
        print(i)
x1 = threading.Thread(name='t1',target=test,args=(0,10))
x2 = threading.Thread(name='t2',target=test,args=(10,20))
x1.start()
x2.start()

这里我们需要调用threading模块,通过threading.Thread我们就可以创建线程,这时我们就有x1和x2两个线程了。


二、线程的并发

按照以前的程序运行逻辑,应该是运行完x1,再运行x2,也就是运行结果应该是0到19顺序输出,而实际的输出结果为:


0

1

2

3

410

511

612

713

814

915

16

17

18

19


而且当我再次运行程序时,结果又发生了变化,结果为:


0

1

2

3

4

5

10

11

612

7

8

139

14

15

16

17

18

19


可以看出,程序并不是运行完一个线程在运行另一个,而是随机交叉运行,这就是python的多线程。


三、threading.Thread () 函数


threading.Thread ()里面有很多参数,主要是我们上面所使用的三个,name参数是给线程命名,如果不写,默认为Tread-1,第二个线程就是Tread-2,以此类推。


target参数可以看出来,传进去的是函数名,也就是说是这个线程准备调用的函数。


我们发现args参数的值实际上是传给了test函数,也就是说,args的值传给了线程调用的函数。



以下是一些常用的 threading.Thread() 方法:

  • target:指定线程要执行的任务函数。
  • args:传递给任务函数的位置参数。
  • kwargs:传递给任务函数的关键字参数。
  • name:设置线程的名称。
  • daemon:设置线程是否为守护线程,如果是守护线程,则主程序退出时会自动销毁该线程。

四、join方法

如果子线程调用join方法,会引起主线程阻塞,通俗来说就是子线程执行完了,才会执行主线程,我们来试一下:

import threading
def test(x,y):
    for i in range(x,y):
        print(i)
x1 = threading.Thread(name='t1',target=test,args=(0,10))
x2 = threading.Thread(name='t2',target=test,args=(10,20))
x1.start()
x1.join()
x2.start()

我们在启动x1线程后,启动join方法。我们会发现,无论我们重新运行几次代码,输出的结果都是0-19顺序输出,也就是说执行完x1后,再执行x2。


总之,threading.Thread() 的 join() 方法用于阻塞当前线程,直到调用该方法的线程执行完毕。如果不使用 join() 方法等待线程结束,线程的输出结果有可能会出现线程混乱,即第一个线程开启后还没有运行结束,第二个线程已经开启了,可能会出现第二个线程先输出的情况。使用 join() 时,第一个线程的任务完全结束后,才会开启第二个线程,输出的结果也将是有序的 。  


五、总结

Python 多线程是指在一个进程中同时执行多个线程,从而实现并发执行。在 Python 中,可以使用 threading 模块来创建和管理线程。以下是一些常用的 threading 模块方法:

  • Thread():创建一个线程对象。
  • start():启动线程。
  • join():阻塞当前线程,直到调用该方法的线程执行完毕。
  • is_alive():判断线程是否还在运行。
  • daemon:设置线程是否为守护线程,如果是守护线程,则主程序退出时会自动销毁该线程。
相关文章
|
4天前
|
安全 Java UED
Java中的多线程编程:从基础到实践
本文深入探讨了Java中的多线程编程,包括线程的创建、生命周期管理以及同步机制。通过实例展示了如何使用Thread类和Runnable接口来创建线程,讨论了线程安全问题及解决策略,如使用synchronized关键字和ReentrantLock类。文章还涵盖了线程间通信的方式,包括wait()、notify()和notifyAll()方法,以及如何避免死锁。此外,还介绍了高级并发工具如CountDownLatch和CyclicBarrier的使用方法。通过综合运用这些技术,可以有效提高多线程程序的性能和可靠性。
|
4天前
|
缓存 Java UED
Java中的多线程编程:从基础到实践
【10月更文挑战第13天】 Java作为一门跨平台的编程语言,其强大的多线程能力一直是其核心优势之一。本文将从最基础的概念讲起,逐步深入探讨Java多线程的实现方式及其应用场景,通过实例讲解帮助读者更好地理解和应用这一技术。
21 3
|
3天前
|
设计模式 开发者 Python
Python编程中的设计模式:从入门到精通####
【10月更文挑战第14天】 本文旨在为Python开发者提供一个关于设计模式的全面指南,通过深入浅出的方式解析常见的设计模式,帮助读者在实际项目中灵活运用这些模式以提升代码质量和可维护性。文章首先概述了设计模式的基本概念和重要性,接着逐一介绍了几种常用的设计模式,并通过具体的Python代码示例展示了它们的实际应用。无论您是Python初学者还是经验丰富的开发者,都能从本文中获得有价值的见解和实用的技巧。 ####
|
6天前
|
Java Python
python知识点100篇系列(16)-python中如何获取线程的返回值
【10月更文挑战第3天】本文介绍了两种在Python中实现多线程并获取返回值的方法。第一种是通过自定义线程类继承`Thread`类,重写`run`和`join`方法来实现;第二种则是利用`concurrent.futures`库,通过`ThreadPoolExecutor`管理线程池,简化了线程管理和结果获取的过程,推荐使用。示例代码展示了这两种方法的具体实现方式。
python知识点100篇系列(16)-python中如何获取线程的返回值
|
9天前
|
搜索推荐 Python
Leecode 101刷题笔记之第五章:和你一起你轻松刷题(Python)
这篇文章是关于LeetCode第101章的刷题笔记,涵盖了多种排序算法的Python实现和两个中等难度的编程练习题的解法。
15 3
|
8天前
|
Java
【编程进阶知识】揭秘Java多线程:并发与顺序编程的奥秘
本文介绍了Java多线程编程的基础,通过对比顺序执行和并发执行的方式,展示了如何使用`run`方法和`start`方法来控制线程的执行模式。文章通过具体示例详细解析了两者的异同及应用场景,帮助读者更好地理解和运用多线程技术。
21 1
|
8天前
|
数据采集 开发框架 数据处理
探索Python的灵活性:简化日常编程任务
【10月更文挑战第7天】 【10月更文挑战第9天】 在本文中,我们将深入探讨Python编程语言的强大功能和灵活性。通过具体的代码示例,我们会展示如何利用Python简化日常编程任务,提高效率。无论是数据处理、自动化脚本还是Web开发,Python都能提供简洁而强大的解决方案。我们还将讨论一些最佳实践,帮助你编写更清晰、更高效的代码。
10 1
|
2天前
|
设计模式 存储 数据库连接
Python编程中的设计模式之美:单例模式的妙用与实现###
本文将深入浅出地探讨Python编程中的一种重要设计模式——单例模式。通过生动的比喻、清晰的逻辑和实用的代码示例,让读者轻松理解单例模式的核心概念、应用场景及如何在Python中高效实现。无论是初学者还是有经验的开发者,都能从中获得启发,提升对设计模式的理解和应用能力。 ###
|
9天前
|
网络协议 安全 Java
难懂,误点!将多线程技术应用于Python的异步事件循环
难懂,误点!将多线程技术应用于Python的异步事件循环
31 0
|
9天前
|
存储 开发者 Python
Python编程入门:构建你的第一个程序
【10月更文挑战第8天】本文旨在为初学者提供一个简单的Python编程入门指南。我们将从安装Python环境开始,逐步介绍如何编写、运行和理解一个简单的Python程序。文章将通过一个实际的代码示例来展示Python的基本语法和结构,帮助读者快速上手Python编程。