python socket recv 阻塞_为什么python async awit 遇到socket.recv阻塞不会切换到其他任务?...

不知道你的 self.recv() 是如何写的,源代码中 create_connection (创建 tcp 连接的方法) 返回的 reader是这样实现的:

async def _wait_for_data(self, func_name):

# 调用通道的 resume_reading 方法,然后等待 数据传输过来(等待 feed_data() or feed_eof() 被调用,self._waiter 就可以结束等待了)

"""Wait until feed_data() or feed_eof() is called.

If stream was paused, automatically resume it.

"""

if self._waiter is not None:

raise RuntimeError(

f'{func_name}() called while another coroutine is '

f'already waiting for incoming data')

assert not self._eof, '_wait_for_data after EOF'

# Waiting for data while paused will make deadlock, so prevent it.

# This is essential for readexactly(n) for case when n > self._limit.

if self._paused: # 如果现在是暂停状态

self._paused = False # 修改为False

self._transport.resume_reading()

# 调用 通道的 resume_reading() 方法恢复读取状态,修改通道的暂停状态,

# 然后使用 selector (modify 修改已经注册的该通道绑定的 fd )或(register注册该 fd )

self._waiter = self._loop.create_future()

try:

await self._waiter

finally:

self._waiter = None

async def read(self, n=-1):

....

if not self._buffer and not self._eof: # 如果缓存中没有数据,就等待 _wait_for_data

await self._wait_for_data('read')

...

首先判断缓存区是否有数据,没有的话 就会创建一个 future 挂起,直到 future 得到 result(即有可读事件的fd的事件处理器被调用)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值