|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 Stubborn 于 2020-5-26 17:07 编辑
复制代码
本帖最后由 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()
复制代码
写的有点乱,见谅
|
|