【Python零基础入门篇 · 21】:多线程的封装和使用、线程的同步、互斥锁、执行的任务有参数

简介: 【Python零基础入门篇 · 21】:多线程的封装和使用、线程的同步、互斥锁、执行的任务有参数

一、多任务的概念


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


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


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




二、多线程


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


1、主线程和子线程


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


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


  • 线程模块:threading


  • 创建子线程:Thread()


  • 开启线程:start()


2、基本代码演示


下图的代码逻辑:


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


105696ddff7643f4ac7b5acca58122f1.png


3、 setDaemon(True)的使用


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


代码逻辑:


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


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

a9fa7e355c5f49c8875c2fbd094381a9.png


4、join()的使用


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


代码逻辑


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

78d397e4c6984c8dbaaab2cb2704117d.png483caec91b8f4b82835a54540032659a.png



5、setName()和getName()的使用


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


getName():获取线程名字

e20c23e9dbbc43bf8d1e54f3b596fb10.png


三、线程的无序


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


image.png



四、线程的封装


代码逻辑


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


f8c5b952d27a434db95abee33b6ed5cd.png


相关文章
|
3月前
|
供应链 并行计算 算法
1行Python搞定高频任务!26个实用技巧解决日常+进阶需求
本文整理了26个Python极简技巧,涵盖日常高频操作与进阶玩法,助你用最少代码高效解决问题,提升编程效率。适合各阶段Python学习者参考。
138 27
|
5月前
|
人工智能 安全 调度
Python并发编程之线程同步详解
并发编程在Python中至关重要,线程同步确保多线程程序正确运行。本文详解线程同步机制,包括互斥锁、信号量、事件、条件变量和队列,探讨全局解释器锁(GIL)的影响及解决线程同步问题的最佳实践,如避免全局变量、使用线程安全数据结构、精细化锁的使用等。通过示例代码帮助开发者理解并提升多线程程序的性能与可靠性。
200 0
|
2月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
290 0
|
4月前
|
数据采集 消息中间件 并行计算
Python多线程与多进程性能对比:从原理到实战的深度解析
在Python编程中,多线程与多进程是提升并发性能的关键手段。本文通过实验数据、代码示例和通俗比喻,深入解析两者在不同任务类型下的性能表现,帮助开发者科学选择并发策略,优化程序效率。
316 1
|
4月前
|
人工智能 自然语言处理 安全
Python构建MCP服务器:从工具封装到AI集成的全流程实践
MCP协议为AI提供标准化工具调用接口,助力模型高效操作现实世界。
862 1
|
5月前
|
数据采集 监控 调度
干货分享“用 多线程 爬取数据”:单线程 + 协程的效率反超 3 倍,这才是 Python 异步的正确打开方式
在 Python 爬虫中,多线程因 GIL 和切换开销效率低下,而协程通过用户态调度实现高并发,大幅提升爬取效率。本文详解协程原理、实战对比多线程性能,并提供最佳实践,助你掌握异步爬虫核心技术。
|
5月前
|
数据采集 存储 Java
多线程Python爬虫:加速大规模学术文献采集
多线程Python爬虫:加速大规模学术文献采集
|
2月前
|
Java
如何在Java中进行多线程编程
Java多线程编程常用方式包括:继承Thread类、实现Runnable接口、Callable接口(可返回结果)及使用线程池。推荐线程池以提升性能,避免频繁创建线程。结合同步与通信机制,可有效管理并发任务。
169 6
|
5月前
|
Java API 微服务
为什么虚拟线程将改变Java并发编程?
为什么虚拟线程将改变Java并发编程?
309 83
|
3月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
268 16

热门文章

最新文章

推荐镜像

更多