主页 > 知识库 > python中使用asyncio实现异步IO实例分析

python中使用asyncio实现异步IO实例分析

热门标签:辽宁智能外呼系统需要多少钱 阿里电话机器人对话 qt百度地图标注 螳螂科技外呼系统怎么用 正安县地图标注app 电销机器人系统厂家郑州 地图地图标注有叹号 举办过冬奥会的城市地图标注 400电话申请资格

1、说明

Python实现异步IO非常简单,asyncio是Python 3.4版本引入的标准库,直接内置了对异步IO的支持。

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

2、实例

import asyncio
@asyncio.coroutine
def wget(host):
  print('wget %s...' % host)
  connect = asyncio.open_connection(host, 80)
  reader, writer = yield from connect
  header = 'GET / HTTP/1.0\r\nHost: %s\r\n\r\n' % host
  writer.write(header.encode('utf-8'))
  yield from writer.drain()
  while True:
    line = yield from reader.readline()
    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()

知识点扩展:

数据流(Streams)

数据流(Streams)是用于处理网络连接的高阶异步/等待就绪(async/await-ready)原语,可以在不使用回调和底层传输协议的情况下发送和接收数据。

以下是一个用asyncio实现的TCP回显客户端:

import asyncio

async def tcp_echo_client(message):
  reader, writer = await asyncio.open_connection(
    '127.0.0.1', 8888)

  print(f'Send: {message!r}')
  writer.write(message.encode())

  data = await reader.read(100)
  print(f'Received: {data.decode()!r}')

  print('Close the connection')
  writer.close()
  await writer.wait_closed()

asyncio.run(tcp_echo_client('Hello World!'))

到此这篇关于python中使用asyncio实现异步IO实例分析的文章就介绍到这了,更多相关python中使用asyncio实现异步IO内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • Python 异步协程函数原理及实例详解
  • Python异步编程之协程任务的调度操作实例分析
  • python中asyncio异步编程学习
  • Python协程asyncio异步编程笔记分享

标签:淘宝好评回访 信阳 随州 济源 合肥 阜新 兴安盟 昭通

巨人网络通讯声明:本文标题《python中使用asyncio实现异步IO实例分析》,本文关键词  python,中,使用,asyncio,实现,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《python中使用asyncio实现异步IO实例分析》相关的同类信息!
  • 本页收集关于python中使用asyncio实现异步IO实例分析的相关信息资讯供网民参考!
  • 推荐文章