- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在将 Clojure 的 core.async 与所谓的 Reactive Extensions (Rx) 和 FRP 进行比较时,我似乎有点困惑一般的。他们似乎解决了类似的异步问题,所以我想知道主要区别是什么,以及在什么情况下更喜欢其中一种。有人可以解释一下吗?
编辑:为了鼓励更深入的答案,我想让问题更具体:
Core.async 允许我编写看起来同步的代码。然而,据我了解,FRP 仅需要一层嵌套回调(所有处理逻辑的函数都作为参数传递给 FRP API)。这似乎两种方法都使得回调金字塔变得不必要。确实,在 JS 中我必须多次编写 function() {...}
,但主要问题,即嵌套回调,在 FRP 中也消失了。我说得对吗?
“FRP通过控制流完成消息的通信”您(某人)能给出更具体的解释吗?
我不能像传递 channel 一样传递 FRP 的可观察端点吗?
总的来说,我了解这两种方法的历史来源,并且我在这两种方法中都尝试过一些教程。然而,我似乎因差异的不明显性而“瘫痪”。是否有一些代码示例很难用其中一个编写而使用另一个很容易?其架构原因是什么?
最佳答案
我认为主要问题是您对所解决问题的假设并不完全如此,因为它们都没有解决异步“问题”。
FRP
的主要思想是更改的传播,请考虑完成与 Excel 相同的操作,即在级联中定义相互依赖的单元格,并且当一个单元格更改时,级联上的所有依赖单元都会重新计算。
core.async
主要思想是系统分解,可以认为是在 core.async
中的不同进程中间使用 queue
来分离关注点> 案例而不是队列,您有 channel ,但您明白了。
因此,删除金字塔代码并不是这两种技术的目标,它们在不同的抽象层上运行。
完成通信和流量控制的思路取自the original core async post .
While there are various mechanisms to make events/callbacks cleaner (FRP, Rx/Observables) they don't change their fundamental nature, which is that upon an event an arbitrary amount of other code is run, possibly on the same thread, leading to admonitions such as "don't do too much work in your handler", and phrases like "callback hell".
换句话来说,如果事件处理程序中有业务域代码,那么您就已经完成了X 事件处理以及X 发生时要做什么强>.
这就是 core.async 解决的问题,因为在中间引入队列/ channel 有助于更好地分离关注点。
有关回调和将可观察端点作为参数传递的所有问题都只是实现问题,它实际上取决于 Rx
实现和 API。
如果你看React reusable components你确实没有看到太多的回调 hell ,并且你明白了传递可观察量的想法。
即使Rx
可用于对任何数据流进行建模,但更常用于UI渲染(a-la Excel),以简化在您更新 View 时的更新方式模型更改。
另一方面,当任意两个子系统相互通信时,Core.Async
可用于建模关注点分离(与队列相同的使用场景),在 UI 渲染上使用它链的主要思想是分离:
因此,您可以将 core.async
和 FRP
放在一起,因为 core.async
将分离关注点,而 FRP
code> 将在模型更新后定义级联数据流。
关于asynchronous - 比较 core.async 和函数响应式编程 (+Rx),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20632512/
我有带皮肤的 DNN。我的 head 标签有 runat="server"所以我尝试在 head 标签内添加一个标签 "> 在后面的代码中,我在属性中设置了 var GoogleAPIkey。问题是它
我在 Node.JS 中有一个导出模块 exports.doSomethingImportant= function(req, res) { var id = req.params.id; Demo.
我是 F# 的新手,我一直在阅读 F# for Fun and Profit。在为什么使用 F#? 系列中,有一个 post描述异步代码。我遇到了 Async.StartChild函数,我不明白为什么
File 中有一堆相当方便的方法类,如 ReadAll***/WriteAll***/AppendAll***。 我遇到过很多情况,当我需要它们的异步对应物时,但它们根本不存在。 为什么?有什么陷阱吗
我最近开始做一个 Node 项目,并且一直在使用 async 库。我有点困惑哪个选项会更快。在某些数据上使用 async.map 并获取其结果,或使用 async.each 迭代一组用户并将他们的相应
您好,我正在试用 Springs 异步执行器,发现您可以使用 @Async。我想知道是否有可能在 @Async 中使用 @Async,要求是需要将任务委托(delegate)给 @Async 方法在第
我需要支持取消一个函数,该函数返回一个可以在启动后取消的对象。在我的例子中,requester 类位于我无法修改的第 3 方库中。 actor MyActor { ... func d
假设 asyncSendMsg不返回任何内容,我想在另一个异步块中启动它,但不等待它完成,这之间有什么区别: async { //(...async stuff...) for msg
我想用 Mocha 测试异步代码. 我跟着这个教程testing-promises-with-mocha .最后,它说最好的方法是 async/await。 以下是我的代码,我打算将 setTimeo
正如我有限(甚至错误)的理解,Async.StartImmediate 和 Async.RunSynchronously 在当前线程上启动异步计算。那么这两个功能究竟有什么区别呢?谁能帮忙解释一下?
我有一行使用await fetch() 的代码。我正在使用一些调用 eval("await fetch ...etc...") 的脚本注入(inject),但问题是 await 在执行时不会执行从ev
我正在尝试使用 nodeJS 构建一个网络抓取工具,它在网站的 HTML 中搜索图像,缓存图像源 URL,然后搜索最大尺寸的图像。 我遇到的问题是 deliverLargestImage() 在循环遍
我想结合使用 async.each 和 async.series,但得到了意想不到的结果。 async.each([1, 2], function(item, nloop) { async.s
我的代码有问题吗?我使用 async.eachSeries 但我的结果总是抛出 undefined。 这里是我的代码: async.eachSeries([1,2,3], function(data,
我想在 trait 中编写异步函数,但是因为 async fn in traits 还不被支持,我试图找到等效的方法接口(interface)。这是我在 Rust nightly (2019-01-0
async setMyPhotos() { const newPhotos = await Promise.all(newPhotoPromises); someOtherPromise();
async.js 中 async.each 与 async.every 的区别?似乎两者都相同,只是 async.every 返回结果。纠正我,我错了。 最佳答案 每个异步 .each(coll, i
我正在尝试对一组项目运行 async.each。 对于每个项目,我想运行一个 async.waterfall。请参阅下面的代码。 var ids = [1, 2]; async.each(ids,
我的目标是测试 API 调用,将延迟考虑在内。我的灵感来自 this post . 我设计了一个沙箱,其中模拟 API 需要 1000 毫秒来响应和更改全局变量 result 的值。测试检查 500
async.each 是否作为异步数组迭代工作? async.eachSeries 是否作为同步数组迭代工作?(它实际上等待响应) 我问这些是因为两者都有回调,但 async.each 的工作方式类似
我是一名优秀的程序员,十分优秀!