Python 中的异步与同步深度解析(实践记录)

2025-03-29 02:50

本文主要是介绍Python 中的异步与同步深度解析(实践记录),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际...

Python中的异步与同步:深度解析与实践

在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键。这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际代码示例来加深理解。

异步与同步的定义

异步

异步意味着多任务处理,任务之间的执行没有严格的先后顺序,甚至可以同时运行。这就好比你一边听音乐,一边浏览网页,听音乐和浏览网页这两个任务之间互不干扰,多条任务的执行路径同时存在,程序有多个“主线”并行处理任务。

同步

同步同样是处理多任务,但任务之间有严格的先后顺序。只有前一个任务执行完成,下一个任务才能开始。这类似于你排队买东西,必须一个人买完,下一个人才能接着买,整个过程只有一条“主线”。

阻塞与非阻塞的概念

阻塞

从调用者的角度来看,如果在调用某个操作时,程序被卡住,无法继续向下执行,必须等待该操作完成,这种情况就是阻塞。比如你打电话叫外卖,在等待外卖送达的这段时间里,你什么其他事都做不了,只能干等着,这就是“阻塞”状态。

非阻塞

当调用某个操作时,程序不会被卡住,能够继续向下执行,无需等待该操作完成,这就是非阻塞。还是以叫外卖为例,你下单后可以继续做自己的事情,不用一直等着外卖,这就是“非阻塞”状态。

同步阻塞与异步非阻塞示例

下面通过Python代码来具体展示异步和同步的工作方式。这里我们使用multiprocessing模块中的Pool来创建进程池,实现多任务处理。

from multiprocessing import Poolwww.chinasem.cn
impoandroidrt time
import os
def water():
 China编程   """烧水"""
    print(f"子进程 pid={os.getpid()}")
    for i in range(5):
        print("正在烧水中")
        time.sleep(0.5)
    return "水烧开了"
def handle_water(message):
    """接收烧开水的信息"""
    print(f"进程pid={os.getpid()} 收到了异步任务的结束信息: {message}")
pool = Pool(3)
print(f"主进程 pid={os.getpid()}")
for i in range(3):
    print("打游戏")
    time.sleep(0.5)
# 回调
pool.apply_async(water, callback=handle_water)  # 异步添加任务
for i in range(20):
    print("打游戏")
    time.sleep(0.5)
pool.close()
pool.join()

在这段代码中:

  • 首先创建了一个进程池Pool,最大进程数为3。
  • 主进程先执行一段“打游戏”的操作,循环3次,每次间隔0.5秒。
  • 然后使用pool.apply_async方法异步地添加water任务到进程池,并设置了回调函数handle_waterwater任务模拟烧水过程,会打印当前子进程IandroidD并每隔0.5秒输出“正在烧水中”,完成后返回“水烧开了”。handle_water函数用于接收water任务完成后的信息并打印。
  • 接着主进程继续执行“打游戏”操作,循环20次,每次间隔0.5秒。这期间,water任务在后台异步执行。
  • 最后,调用pool.close()关闭进程池,不再接受新任务,pool.join()让主进程等待所有子进程完成任务后再结束。

通过这个示例,可以清晰地看到异步任务在后台执行,不会QtYpQYAk阻塞主进程的其他操作,体现了异步非阻塞的特性。如果将pool.apply_async换成pool.apply,那么就是同步阻塞的效果,water任务执行时会阻塞主进程,直到任务完成才会继续执行后续代码。

理解异步、同步、阻塞和非阻塞的概念,能帮助开发者根据实际需求优化程序性能,合理利用系统资源,让程序运行得更加高效和灵活。无论是处理I/O密集型任务,还是CPU密集型任务,选择合适的执行方式都是关键。

到此这篇关于Python 中的异步与同步:解析与实践的文章就介绍到这了,更多相关Python 异步与同步内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Python 中的异步与同步深度解析(实践记录)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154003

相关文章

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

如何在Java Spring实现异步执行(详细篇)

《如何在JavaSpring实现异步执行(详细篇)》Spring框架通过@Async、Executor等实现异步执行,提升系统性能与响应速度,支持自定义线程池管理并发,本文给大家介绍如何在Sprin... 目录前言1. 使用 @Async 实现异步执行1.1 启用异步执行支持1.2 创建异步方法1.3 调用

Spring Boot 3.x 中 WebClient 示例详解析

《SpringBoot3.x中WebClient示例详解析》SpringBoot3.x中WebClient是响应式HTTP客户端,替代RestTemplate,支持异步非阻塞请求,涵盖GET... 目录Spring Boot 3.x 中 WebClient 全面详解及示例1. WebClient 简介2.

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分