Python学习笔记__20.2章 asyncio

本文介绍了Python中的异步IO库asyncio,详细解释了其核心概念如事件循环、协程、任务等,并通过实例展示了如何使用asyncio进行异步网络连接。

# 这是学习廖雪峰老师python教程的学习笔记

1、概览

asyncioPython 3.4版本引入的标准库,直接内置了对异步IO的支持

asyncio的编程模型就是一个消息循环。我们从asyncio模块中直接获取一个EventLoop的引用,然后把需要执行的协程扔到EventLoop中执行,就实现了异步IO。

1.1、asyncioio的关键字

  • event_loop      事件循环:程序开启一个无限循环,把一些函数注册到事件循环上,当满足事件发生的时候,调用相应的协程函数

  • coroutine      协程:协程对象,指一个使用async关键字定义的函数,它的调用不会立即执行函数,而是会返回一个协程对象。协程对象需要注册到事件循环,由事件循环调用。

  • task      任务:一个协程对象就是一个原生可以挂起的函数,任务则是对协程进一步封装,其中包含了任务的各种状态

  • future: 代表将来执行或没有执行的任务的结果。它和task上没有本质上的区别

  • async/await      关键字:python3.5用于定义协程的关键字,async定义一个协程,await用于挂起阻塞的异步调用接口。

 

 

 

2、实例

2.1、用asyncio实现Hello world

import asyncio

 

@asyncio.coroutine # generator标记为coroutine类型

def hello():

    print("Hello world!")

    r = yield from asyncio.sleep(1) # 异步调用asyncio.sleep(1)

    print("Hello again!")

 

 

loop = asyncio.get_event_loop() # 创建消息事件,开启了事件循环

loop.run_until_complete(hello())  # 将协程对象注册到事件循环,由事件循环调用

loop.close() # 关闭事件

asyncio.sleep(1)看成是一个耗时1秒的IO操作,在此期间,主线程并未等待,而是去执行EventLoop中其他可以执行的coroutine了,因此可以实现并发执行。

因为loop里只有一个事件【hello()】,所以会暂停1秒,打印“hello again

2.2、用Task封装两个coroutine

import threading

import asyncio

 

@asyncio.coroutine # generator标记为coroutine类型

def hello():

    print('Hello world! (%s)' % threading.currentThread()) # 打印当前线程号

    yield from asyncio.sleep(1)

    print('Hello again! (%s)' % threading.currentThread())

 

loop = asyncio.get_event_loop()

tasks = [hello(), hello()] # 定义任务

loop.run_until_complete(asyncio.wait(tasks)) #asyncio.wait()等待子进程终止

loop.close() # 关闭消息事件

 

# 执行过程

Hello world! (<_MainThread(MainThread, started 140735195337472)>)

Hello world! (<_MainThread(MainThread, started 140735195337472)>)

(暂停约1秒)

Hello again! (<_MainThread(MainThread, started 140735195337472)>)

Hello again! (<_MainThread(MainThread, started 140735195337472)>)

# 解析

这里的loop里有两个hello事件,下面简称h1和h2。

  1. 首先h1被执行,打印了"Hello      world",异步执行了asyncio.sleep(1),需要暂停1

  2. loop不会等待,将h1挂起,直接执行h2,又打印了"Hello      world",然后又碰到asyncio.sleep(1),需要暂停1

  3. 1秒后,再次执行h1h2,因为CPU处理速度很快,所以虽然h2h1晚暂停,但是几乎感觉不到

 

2.3、用asyncio的异步网络连接来获取sinasohu163的网站首页

import asyncio

 

@asyncio.coroutine # generator标记为coroutine类型

def wget(host):

    print('wget %s...' % host)

    connect = asyncio.open_connection(host, 80) #创建异步连接

    reader, writer = yield from connect #异步调用connect,返回readerwriter两个实例,这是固定的两个实例

    header = 'GET / HTTP/1.0\r\nHost: %s\r\n\r\n' % host  # 设置header

    writer.write(header.encode('utf-8'))

    yield from writer.drain() # 将设置的header写入connect

    while True:

        line = yield from reader.readline() #读取返回的HTTP

        if line == b'\r\n':

            break

        print('%s header > %s' % (host, line.decode('utf-8').rstrip()))

    # Ignore the body, close the socket

    writer.close()

 

loop = asyncio.get_event_loop()

tasks = [wget(host) for host in ['www.sina.com.cn', 'www.sohu.com', 'www.163.com']]

loop.run_until_complete(asyncio.wait(tasks))

loop.close()

 

# 执行结果

wget www.sohu.com...

wget www.sina.com.cn...

wget www.163.com...

(等待一段时间)

(打印出sohu的header)

www.sohu.com header > HTTP/1.1 200 OK

www.sohu.com header > Content-Type: text/html

...

(打印出sina的header)

www.sina.com.cn header > HTTP/1.1 200 OK

www.sina.com.cn header > Date: Wed, 20 May 2015 04:56:33 GMT

...

(打印出163的header)

www.163.com header > HTTP/1.0 302 Moved Temporarily

www.163.com header > Server: Cdn Cache Server V2.0

3个连接由一个线程通过coroutine并发完成

3、小结

  • asyncio提供了完善的异步IO支持;

  • 异步操作需要在coroutine中通过yield from完成

  • 多个coroutine可以封装成一组Task然后并发执行

 

4、扩展文档

python中重要的模块--asyncio (https://www.cnblogs.com/zhaof/p/8490045.html)

python yield yield from (https://blog.youkuaiyun.com/chenbin520/article/details/78111399?locationNum=7&fps=1)


源码来自:https://pan.quark.cn/s/7a757c0c80ca 《在Neovim中运用Lua的详尽教程》在当代文本编辑器领域,Neovim凭借其卓越的性能、可扩展性以及高度可定制的特点,赢得了程序开发者的广泛青睐。 其中,Lua语言的融入更是为Neovim注入了强大的活力。 本指南将深入剖析如何在Neovim中高效地运用Lua进行配置和插件开发,助你充分发挥这一先进功能的潜力。 一、Lua为何成为Neovim的优选方案经典的Vim脚本语言(Vimscript)虽然功能完备,但其语法结构与现代化编程语言相比显得较为复杂。 与此形成对比的是,Lua是一种精简、轻量且性能卓越的脚本语言,具备易于掌握、易于集成的特点。 因此,Neovim选择Lua作为其核心扩展语言,使得配置和插件开发过程变得更加直观和便捷。 二、安装与设置在Neovim中启用Lua支持通常十分简便,因为Lua是Neovim的固有组件。 然而,为了获得最佳体验,我们建议升级至Neovim的最新版本。 可以通过`vim-plug`或`dein.vim`等包管理工具来安装和管理Lua插件。 三、Lua基础在着手编写Neovim的Lua配置之前,需要对Lua语言的基础语法有所掌握。 Lua支持变量、函数、控制流、表(类似于数组和键值对映射)等核心概念。 它的语法设计简洁明了,便于理解和应用。 例如,定义一个变量并赋值:```lualocal myVariable = "Hello, Neovim!"```四、Lua在Neovim中的实际应用1. 配置文件:Neovim的初始化文件`.vimrc`能够完全采用Lua语言编写,只需在文件首部声明`set runtimepath^=~/.config/nvim ini...
基于STM32 F4的永磁同步电机无位置传感器控制策略研究内容概要:本文围绕基于STM32 F4的永磁同步电机(PMSM)无位置传感器控制策略展开研究,重点探讨在不使用机械式位置传感器的情况下,如何通过算法实现对电机转子位置和速度的精确估算与控制。文中结合STM32 F4高性能微控制器平台,采用如滑模观测器(SMO)、扩展卡尔曼滤波(EKF)或高频注入法等先进观测技术,实现对电机反电动势或磁链的实时估算,进而完成磁场定向控制(FOC)。研究涵盖了控制算法设计、系统建模、仿真验证(可能使用Simulink)以及在嵌入式平台上的代码实现与实验测试,旨在提高电机驱动系统的可靠性、降低成本并增强环境适应性。; 适合人群:具备一定电机控制理论基础和嵌入式开发经验的电气工程、自动化及相关专业的研究生、科研人员及从事电机驱动开发的工程师;熟悉C语言和MATLAB/Simulink工具者更佳。; 使用场景及目标:①为永磁同步电机驱动系统在高端制造、新能源汽车、家用电器等领域提供无位置传感器解决方案的设计参考;②指导开发者在STM32平台上实现高性能FOC控制算法,掌握位置观测器的设计与调试方法;③推动电机控制技术向低成本、高可靠方向发展。; 其他说明:该研究强调理论与实践结合,不仅包含算法仿真,还涉及实际硬件平台的部署与测试,建议读者在学习过程中配合使用STM32开发板和PMSM电机进行实操验证,以深入理解控制策略的动态响应与鲁棒性问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值