当前位置: 首页 > news >正文

株洲网站制作公司有哪些seo网站排名优化软件是什么

株洲网站制作公司有哪些,seo网站排名优化软件是什么,网站模板 自适应,清苑区建设局网站文章目录 1. 同步与异步函数的对比1.1 同步函数1.2 异步函数1.3 对比 2. 管理多个协程与异常处理2.1 并发执行多个协程2.2 错误处理2.3 任务取消 本文将探索Python中同步与异步编程的基本概念及其区别。还会详细介绍如何使用asyncio库来有效管理协程,包括任务的创建…

文章目录

    • 1. 同步与异步函数的对比
      • 1.1 同步函数
      • 1.2 异步函数
      • 1.3 对比
    • 2. 管理多个协程与异常处理
      • 2.1 并发执行多个协程
      • 2.2 错误处理
      • 2.3 任务取消

本文将探索Python中同步与异步编程的基本概念及其区别。还会详细介绍如何使用asyncio库来有效管理协程,包括任务的创建、错误处理和取消等功能。


1. 同步与异步函数的对比

1.1 同步函数

在同步模式下,如果some_function()进行耗时的I/O操作,比如网络请求或文件读取,程序将在此函数执行期间停止执行,直到操作完成。

def fetch_data():data = some_sync_function()  # 耗时操作return data# 同步调用
data = fetch_data()

这种模式下,程序完全阻塞直到some_sync_function()执行完成。

1.2 异步函数

使用asyncawait创建的异步函数可以在执行中暂停并继续执行,无需阻塞程序:

async def fetch_data():data = await some_async_function()  # 异步操作return data

在这种模式下,await关键字使得fetch_datasome_async_function()执行期间暂停,将控制权交还给事件循环,允许执行其他操作。

1.3 对比

特性同步编程异步编程
执行方式阻塞式执行非阻塞式执行
资源利用效率较低,CPU等待I/O高效,CPU可以处理其他任务
复杂性相对简单较复杂,需要理解事件循环
适用场景简单脚本、小工具I/O密集型应用,如Web服务器
控制流线性,易于理解需要使用回调、promises等
库/框架无特殊需求需要支持异步的库(如asyncio
性能受限于I/O等待时间可大幅提高响应速度和吞吐率
错误处理直接处理需要特殊机制处理异常

同步和异步的对比图
在这里插入图片描述

2. 管理多个协程与异常处理

在使用asyncio进行并发编程时,不仅需要管理多个协程的并发执行,同时也需要妥善处理可能出现的错误和取消正在运行的任务。

2.1 并发执行多个协程

asyncio.gather是一个非常实用的函数,它允许同时启动多个协程,并等待所有协程执行完成。这样可以有效地利用时间,因为它允许多个协程并行执行而非顺序执行。

import asyncioasync def count():print("One", end=' ')  # 确保在打印后不自动换行await asyncio.sleep(1)print("Two", end=' ')  # 同样不换行async def main():await asyncio.gather(count(), count(), count())asyncio.run(main())
# 输出:One One One Two Two Two 

count协程会先打印“One”,然后等待1秒,接着打印“Two”。由于使用了asyncio.gather,三个count协程会并行执行,因此总的等待时间仅为1秒,而不是三次各自等待1秒。

加餐:end是干嘛用的

默认情况下,print函数会在每次调用后添加一个换行符,但如果设置end参数为一个空字符串'',那么输出将不会在末尾添加换行符。

2.2 错误处理

asyncio中处理错误是确保程序健壮性和响应性的关键。错误处理通常通过使用try-except块来实现,这允许程序在遇到预期内的异常时优雅地恢复。

import asyncioasync def error_task():raise ValueError("Something went wrong!")async def main():task = asyncio.create_task(error_task())try:await taskexcept ValueError as e:print(f"Caught an error: {e}")asyncio.run(main())
# 输出:Caught an error: Something went wrong!

在这个例子中,error_task协程故意抛出一个ValueError异常。在main函数中,使用try-except块来捕获并处理这个异常。这样的错误处理机制确保了即使在异步任务失败时,程序也能继续运行,从而提高了整体的容错性。

asyncio.create_task 简介

asyncio.create_task()函数用于并行运行协程。此函数将协程封装成一个Task对象,并安排其在事件循环中执行。

2.3 任务取消

asyncio中,取消任务是异步编程中的另一个重要方面,它允许开发者在任务不再需要时终止执行,从而释放资源。

import asyncioasync def cancellable_task():try:print("Task starts")await asyncio.sleep(10)  # 假设这是一个长时间运行的任务print("Task completed")except asyncio.CancelledError:print("Task was cancelled!")async def main():task = asyncio.create_task(cancellable_task())await asyncio.sleep(1)  # 给任务一点时间开始执行task.cancel()  # 取消任务try:await taskexcept asyncio.CancelledError:print("Caught cancellation in main")asyncio.run(main())
# 输出:
# Task starts
# Task was cancelled!
# Caught cancellation in main

在这个例子中,cancellable_task开始执行后,通过调用task.cancel()来请求取消任务。任务中的asyncio.sleep调用会在收到取消请求时抛出一个asyncio.CancelledError。在任务的try-except块中捕获这个异常,可以执行任何必要的清理工作。在main函数中,等待任务完成,并处理可能由任务取消引发的异常。


参考:Synchronous vs Asynchronous Programming: Models, Differences, Use Cases
推荐: python 错误记录

http://www.hkea.cn/news/561801/

相关文章:

  • 山东省建设工程信息网站最近最新的新闻
  • 免费网站建设方案锦绣大地seo官网
  • 电子商务的网站建设牛排seo系统
  • 资源收费网站怎么做网站快速优化排名官网
  • 招标网哪个网站信息可靠百度站长工具网站
  • 郑州七七网站建设互联网推广公司
  • 佛山做外贸网站代理商百度收录技术
  • 公司网站建设需要什么今日热搜第一名
  • 烟台建设企业网站网站快速收录入口
  • 怎么做繁体字网站网络营销公司注册找哪家
  • 做ppt介绍网站吗网站搜索引擎优化工具
  • 深圳网站建设有没有市场百度搜索推广的五大优势
  • 网站建设好的图片百度互联网营销
  • 柳州网站制作公司seo优化什么意思
  • 网站建设做的好的公司淘宝关键词优化怎么弄
  • 手机网站用模版方象科技的企业愿景
  • 沈阳网站建设技术公司排名公司市场营销策划方案
  • 赣州网站建设怎样石家庄最新消息
  • 公司注册地址和经营地址不一致可以吗长春seo招聘
  • 好的做问卷调查的网站好推广有奖励的app平台
  • 有专业设计网站吗百度指数与百度搜索量
  • 网站的整体结构百度云网盘资源搜索引擎入口
  • 咸阳网站建设哪家专业杭州优化公司在线留言
  • 地板网站建设门户网站
  • 新增备案网站负责人人工智能培训心得体会
  • 帮境外赌场做网站是否有风险百度企业号
  • 网站换了服务器百度seo排名优化公司哪家好
  • 海南网站建设制作网络营销效果评估
  • 飞阳建设网站上海广告公司
  • 营销网站导航栏常见网站搜索排名靠前