6

有人可以用更简单的非计算机科学术语向我解释一下 R 中的回调功能(taskCallback、、getTaskCallbackNames... taskCallbackManager等)是什么?我查看了 R 帮助,但我发现信息有点过于抽象。

它的设计目的是什么,用户如何使用它们?

如果有人可以解释一般概念(用 R 和其他计算机语言),并用 R 提供示例,我将非常感激,因为我从来没有真正理解过。它是否必须与递归函数做任何事情,还是我被名称回调误导了?

4

2 回答 2

5

我对 R 了解不多,所以我无法在这里深入研究 R 的任何细节。话虽如此:

通常,在命令式、过程式和函数式编程语言中(可能还有其他一些范式),调用函数将阻塞,直到该函数完成,并将函数的结果传递给调用者。这通常是一种很好的做事方式,但是在某些情况下,我们可能会有一些要求,使其成为不太可行的作案手法。

对于长时间运行的操作,我们可能不想长时间阻塞调用者。根据我们所处的环境,调用者可能无法生成另一个线程,或者可能的线程数量可能太少而无法容纳所需的并行调用数量,因此以这种同步方式执行长时间运行的操作会带来非常糟糕的体验。具有单线程模型和频繁调用服务器的 JavaScript 就是一个典型的例子。

所以回调的基本思想是,调用者不是在实际处理完成时返回被调用函数,而是传入一个回调对象(在 OOP 中,在其他范例中类似的东西,例如回调函数,通常是匿名的,用于函数式编程)。被调用的函数将立即返回,释放调用线程来做其他事情。当长时间运行的进程完成时,回调将被调用,调用者可以在那里处理从长时间运行的进程中给出的结果。

这个模式可以概括一下,所以不仅会在处理结束时调用回调,而且还会处理过程中定期调用,提供某种状态更新,因此调用者可以例如向用户显示一些反馈(状态栏,预计完成时间,...)。另一个常见的添加是调用者在处理任务时取消任务的方法。

这是一般原则。也许更博学的人可以详细说明这如何适用于 R 以及 R 与此一般描述的不同之处。

于 2012-08-13T14:48:59.337 回答
4

可以在此处找到详细信息和示例。

基本思想不处理递归,而是为发出到 R 命令行的每个顶级命令调用一个(或多个函数)。

它的一个用途是在 TeachingDemos 包中,txtStart相关函数使用任务回调将每个命令的副本及其结果输出保存到外部文件,从而创建交互式会话的副本。

于 2012-08-13T18:22:28.317 回答