本帖最后由 qiuyouzhi 于 2021-2-2 19:45 编辑
Hallo
我又来了..不知道解释的对不对
都在注释里了def apply_async(function, args, *, callback):
result = function(*args)
callback(result)
from queue import Queue
from functools import wraps
class Async:
def __init__(self, function, args):
self.function = function
self.args = args
def in_lined_async(function):
@wraps(function) # 没啥用,防止原函数属性被覆盖
def wrapper(*args):
f = function(*args) # 调用
result_queue = Queue() # 新建一个队列
result_queue.put(None) # 这行代码一是为了防止下面的result_queue.get()卡住,二是为了使f.send(result)可以成功运行
while True:
result = result_queue.get() # 从队列里面获取一个值
try:
a = f.send(result) # a 是 Async 这个类,因为在 test 函数里面写了 yield Async(.....)
apply_async(a.function, a.args, callback = result_queue.put) # 调用这个类的function属性(它是一个函数),
# 并把 args 属性作为参数传入,并把这个函数调用后的返回值放到队列里(原因看 apply_async 的定义)
# 这一段完事后,y = yield Async(add, (2, 3)) 这段代码才正式赋值y
except StopIteration:
break
return wrapper
def add(x, y):
return x + y
@in_lined_async
def test():
y = yield Async(add, (2, 3)) # 在这里会挂住,直到调用apply_async那里才会继续
# 这里 y 之所以不是Async这个类,是因为result_queue.get()那里,于是result_queue就空了
# 这里就会堵塞住,无法继续执行,必须等到下一个值被传入
# 而像 other = yield foo 这样的语句的意思是,“返回 foo 的值,这个值返回给调用者的同时,将 other 的值也设置为那个值”。
# 来源:https://fishc.com.cn/thread-56023-1-1.html
print(y)
y = yield Async(add, ("Hello ", "World"))
print(y)
for n in range(5):
y = yield Async(add, (n, n))
print(y)
print("Goodbye")
test()
写的有点乱,见谅 |