【Python零基础入门篇 · 31】:多线程、线程的无序和封装

简介: 【Python零基础入门篇 · 31】:多线程、线程的无序和封装

多任务的概念


并发: 在一段时间内交替去执行任务


并行: 对于多核cpu处理多任务,操作系统会给cpu的每个内核安排一个执行的软件,多个内核是真正的一起执行软件。


这里需要注意多核cpu是并行的执行多任务,始终有多个软件一起执行。





多线程


使用threading模块里面的Thread类创建出实例对象, 然后通过**start()**方法真正的去产生一个新的线程。



主线程和子线程


解释器中来执行代码的叫做主线程。


通过start()方法创建出来的叫做子线程。


  • 线程模块:threading


  • 创建子线程:Thread()


  • 开启线程:start()


基本代码演示


  • 下图的代码逻辑:


  • 开启子线程时会**同时运行func()和funb()**函数,同时等待两秒,相当于减少了两秒时间


67efe5b037f74b1a8fec2a05e54216f1.png



setDaemon(True)的使用


守护线程,主线程执行完了,子线程也会跟着结束,要放在start()前面。


代码逻辑:


   过滤执行代码__name__=='__main__'下的代码开始执行,执行到 t1.start()和t2.start()时,同时运行 func()和funb() 函数,然后程序继续运行 t1.start()和t2.start() 后的代码。


   print(123)是主线程的代码,运行完主线程的代码之后子线程也会跟着结束,因为 t1.start()和t2.start() 中有时间等待,在这个等待的时间里子线程已经随着主线程一起结束,所以后面的代码执行无法执行。


34c7efb5fa034c468620982f22e88253.png



join()的使用


阻塞主线程:暂停的作用,等添加了join的子线程执行完,主线程才继续执行,要放在start()后面。


代码逻辑:


  • 过滤执行代码__name__=='__main__'下的代码开始执行,执行到 t1.join()时会等到 fund()函数运行结束后,才继续执行 t1.join()后的代码

1422d6a66f1f48638137afa5309ab4ea.png


setName()和getName()的使用


setName():修改线程的名字,括号中写入的是所要修改成的名字


getName():获取线程名字


d6e91b13c1324eceace138803abd227a.png


线程的无序


threading.current_thread().name——显示当前的线程对象名


f61c41290f8349faa9a3f8e5fe319d8a.png



线程的封装


代码逻辑:


  • 过滤执行代码__name__=='__main__'下的代码开始执行,运行到 my.start() 时会调用 Mythread 类中的 run() 方法,不会调用text()方法


9b36a176f6364d7aaf705360d4af7af2.png

相关文章
|
4天前
|
数据采集 负载均衡 安全
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
本文提供了多个多线程编程问题的解决方案,包括设计有限阻塞队列、多线程网页爬虫、红绿灯路口等,每个问题都给出了至少一种实现方法,涵盖了互斥锁、条件变量、信号量等线程同步机制的使用。
LeetCode刷题 多线程编程九则 | 1188. 设计有限阻塞队列 1242. 多线程网页爬虫 1279. 红绿灯路口
|
6天前
|
Python
5-5|python开启多线程入口必须在main,从python线程(而不是main线程)启动pyQt线程有什么坏处?...
5-5|python开启多线程入口必须在main,从python线程(而不是main线程)启动pyQt线程有什么坏处?...
|
3天前
|
NoSQL 网络协议 Unix
1)Redis 属于单线程还是多线程?不同版本之间有什么区别?
1)Redis 属于单线程还是多线程?不同版本之间有什么区别?
8 0
|
3天前
|
数据采集 Linux 调度
Python之多线程与多进程
Python之多线程与多进程
10 0
|
4天前
|
并行计算 关系型数据库 MySQL
30天拿下Python之使用多线程
30天拿下Python之使用多线程
14 0
|
4天前
|
Java
COMATE插件实现使用线程池高级并发模型简化多线程编程
本文介绍了COMATE插件的使用,该插件通过线程池实现高级并发模型,简化了多线程编程的过程,并提供了生成结果和代码参考。
|
2月前
|
存储 监控 Java
Java多线程优化:提高线程池性能的技巧与实践
Java多线程优化:提高线程池性能的技巧与实践
64 1
|
12天前
|
Java Spring
spring多线程实现+合理设置最大线程数和核心线程数
本文介绍了手动设置线程池时的最大线程数和核心线程数配置方法,建议根据CPU核数及程序类型(CPU密集型或IO密集型)来合理设定。对于IO密集型,核心线程数设为CPU核数的两倍;CPU密集型则设为CPU核数加一。此外,还讨论了`maxPoolSize`、`keepAliveTime`、`allowCoreThreadTimeout`和`queueCapacity`等参数的设置策略,以确保线程池高效稳定运行。
72 10
spring多线程实现+合理设置最大线程数和核心线程数
|
20天前
|
Java 数据库 Android开发
一个Android App最少有几个线程?实现多线程的方式有哪些?
本文介绍了Android多线程编程的重要性及其实现方法,涵盖了基本概念、常见线程类型(如主线程、工作线程)以及多种多线程实现方式(如`Thread`、`HandlerThread`、`Executors`、Kotlin协程等)。通过合理的多线程管理,可大幅提升应用性能和用户体验。
35 15
一个Android App最少有几个线程?实现多线程的方式有哪些?
|
22天前
|
Java 数据库 Android开发
一个Android App最少有几个线程?实现多线程的方式有哪些?
本文介绍了Android应用开发中的多线程编程,涵盖基本概念、常见实现方式及最佳实践。主要内容包括主线程与工作线程的作用、多线程的多种实现方法(如 `Thread`、`HandlerThread`、`Executors` 和 Kotlin 协程),以及如何避免内存泄漏和合理使用线程池。通过有效的多线程管理,可以显著提升应用性能和用户体验。
38 10
下一篇
无影云桌面