- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试掌握 NDB 引入的异步操作,我想使用 @ndb.tasklet
来异步我的一些工作。
简单的例子是在重写的 get_or_insert_async
中生成 string_id
这是处理事情的正确方法吗?这里有什么可以改进的?
@classmethod
@ndb.tasklet
def get_or_insert_async(cls, *args):
id = cls.make_string_id(*args)
model = yield super(MyModel, cls).get_or_insert_async(id)
raise ndb.Return(model)
另一个例子是以扇出的方式在循环中做一些事情。这是正确的吗?
@classmethod
@ndb.tasklet
def do_stuff(cls, some_collection):
@ndb.tasklet
def internal_tasklet(data):
do_some_long_taking_stuff(data)
id = make_stuff_needed_for_id(data)
model = yield cls.get_or_insert_async(id)
model.long_processing(data)
yield model.put_async()
raise ndb.Return(None)
for data in some_collection:
# will it parallelise internal_tasklet execution?
yield internal_tasklet(data)
raise ndb.Return(None)
编辑:
按照整个概念的理解,yield
在这里提供一个 Future
对象,然后并行收集(如果可能)并异步执行。我说得对吗?
在 Nick 的提示之后(是您的意思吗?):
@classmethod
@ndb.tasklet
def do_stuff(cls, some_collection):
@ndb.tasklet
def internal_tasklet(data):
do_some_long_taking_stuff(data)
id = make_stuff_needed_for_id(data)
model = yield cls.get_or_insert_async(id)
model.long_processing(data)
raise ndb.Return(model) # change here
models = []
for data in some_collection:
# will it parallelise internal_tasklet execution?
m = yield internal_tasklet(data) # change here
models.appedn(m) # change here
keys = yield ndb.put_multi_async(models) # change here
raise ndb.Return(keys) # change here
编辑:
新修订版……
@classmethod
@ndb.tasklet
def do_stuff(cls, some_collection):
@ndb.tasklet
def internal_tasklet(data):
do_some_long_taking_stuff(data)
id = make_stuff_needed_for_id(data)
model = yield cls.get_or_insert_async(id)
model.long_processing(data)
raise ndb.Return(model)
futures = []
for data in some_collection:
# tasklets won't run in parallel but while
# one is waiting on a yield (and RPC underneath)
# the other will advance it's execution
# up to a next yield or return
fut = internal_tasklet(data)) # change here
futures.append(fut) # change here
Future.wait_all(futures) # change here
models = [fut.get_result() for fut in futures]
keys = yield ndb.put_multi_async(models) # change here
raise ndb.Return(keys) # change here
最佳答案
如果你想做的只是用不同的参数调用一些异步的东西,你不需要使用 tasklets - 只需返回包装函数的返回值,就像这样:
def get_or_insert_async(cls, *args):
id = cls.make_string_id(*args)
return super(MyModel, cls).get_or_insert_async(id)
不过,出于以下几个原因,我对此持谨慎态度:您正在更改内置函数的含义,这通常是个坏主意,您正在更改签名(位置参数但没有关键字参数),并且您没有将额外的参数传递给原始函数。
对于你的第二个例子,一次产生一个东西将迫使 NDB 等待它们完成——'yield' 是 'wait' 的同义词。相反,为集合中的每个元素执行 tasklet 函数,然后同时等待所有元素(通过调用列表上的 yield)。
关于python - 如何覆盖异步 NDB 方法并编写自己的 tasklet,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10017880/
当tasklet在执行过程中触发硬件中断时,tasklet的状态会发生什么变化? 最佳答案 Tasklet 是下半部分。它们在软中断上下文中运行,而不是在硬件中断上下文中运行。所以硬件中断总是启用的。
我有一个要求,其中一个 tasklet 将目录中的所有文件存储在一个数组列表中。列表的大小存储在作业执行上下文中。稍后在另一个步骤中从另一个 tasklet 访问此计数。它是如何做到这一点的。我试图存
我有一个 tasklet 将一些信息设置到我的 JobContext 中,另一个 tasklet 检查一些东西以了解我是否可以执行批处理中的后续步骤。 如果我在我的工作流程中使用两个不同的步骤,这两个
在处理tasklet时,中断是否被禁用,因为它们应该在中断上下文中运行。如果在处理tasklet时中断,那么将它们称为下半部分机制有什么意义,因为它与禁用中断的顶部情况相同。或者,tasklet 是否
我想构建一个内核模块,它会在按下 f5 键时运行一个 tasklet。 我知道如何初始化一个 tasklet,但是如何在我的模块中获取事件?如何使用 request_irq 确定是否按下了 f5? 最
在我的大学里,我正在从事一个涉及一些内核编程的项目。其中一部分是可加载内核模块,它为某个给定的中断注册中断处理程序。 现在我已经共享了中断处理程序和 tasklet 使用的数据结构,我想知道我是否可以
我知道 Tasklets 是延迟中断处理程序,它们在中断上下文中执行,除了它们具有最高优先级(当然高于用户进程)。 但是,如果我们有多个 Tasklets 有很多工作要做,这些 Tasklets 是如
我正在使用 Google App Engine SDK 1.7.3 和 NDB 来访问数据存储区。 我应该如何从事务性tasklet 中运行非事务性tasklet? 我首先想到的是以下内容: @ndb
我有一个中断处理程序,它按如下方式安排一个 tasklet(伪代码)- struct tasklet_struct mytasklet; void my_tasklet_function(unsign
你好,我正在尝试使用 call_usermodehelper_exec 从 tasklet 运行用户空间进程,该进程是在带有 Allwinner SOC 的 ARM 板(来自 Olimex)的内核模块
新的 Mono Continuations/Tasklet 框架的主要性能开销(gc/堆栈复制...)是什么? 与 Lua Coroutine 和 stackless python 等其他框架相比,这
来自 documentation : An NDB tasklet is a piece of code that might run concurrently with other code. If
我正在尝试将参数从 tasklet 安全地传递到同一作业中的步骤。 我的工作包括 3 个 tasklet(step1,step2,step3) 一个接一个,最后一个 step4(processor,r
我正在使用 GAE,但我意识到当我尝试启动 .py 文件时出现此错误。我能做些什么?谢谢 python3 test.py runserver Traceback (most recent call
如何获取执行 tasklet 函数的任务的 pid。 current->pid 不会工作,因为 tasklet 在中断上下文中运行。当前很可能指的是被中断的任务。 最佳答案 从您需要 pid 的任务中
据说 Softirqs/tasklets 在中断上下文中执行我有以下关于中断上下文底部的问题。 Q1)如果我们尝试让 tasklet 进入休眠状态(中断上下文下半部分)会发生什么(考虑 tasklet
我正在尝试掌握 NDB 引入的异步操作,我想使用 @ndb.tasklet 来异步我的一些工作。 简单的例子是在重写的 get_or_insert_async 中生成 string_id 这是处理事情
GvRs App Engine ndb Library以及monocle并且——据我所知——现代 Javascript 使用生成器使异步代码看起来像阻塞代码。 事物用@ndb.tasklet装饰。他们
我是一个 Linux 设备驱动新手,想知道 tasklet 和 workqueue 之间的确切区别。我有以下疑问: Which kernel stack do interrupts, tasklet
我是一名优秀的程序员,十分优秀!