每当 FRP 网络在 Reactive Banana 中“做某事”时,都是因为它对某些输入事件做出反应。它在系统外部执行任何可观察到的操作的唯一方法是连接外部系统以对其生成的事件做出反应(使用reactimate
).
因此,如果您所做的只是通过生成输出事件来立即对输入事件做出反应,那么不,您不会找到太多使用的理由Behaviour
.
Behaviour
对于生成依赖于多个事件流的程序行为非常有用,您必须记住事件发生在不同的时间.
An Event
有发生;它具有价值的特定时刻。 ABehaviour
在所有时间点都有一个值,没有特殊的时刻(除了changes
,这很方便,但有点破坏模型)。
许多 GUI 都熟悉的一个简单示例是,如果我想对鼠标单击做出反应,并让 Shift 键单击执行与未按住 Shift 键时单击不同的操作。与一个Behaviour
保存一个指示是否按住 Shift 键的值,这很简单。如果我刚刚有Event
对于 Shift 键按下/释放和鼠标单击来说要困难得多。
除了更难之外,它的水平也更低。为什么我必须做复杂的摆弄才能实现像 Shift-Click 这样的简单概念?这choice之间Behaviour
and Event
是一个有用的抽象,可以用更接近您在编程世界之外思考它们的方式来实现程序的概念。
这里的一个例子是游戏世界中的可移动物体。我could有一个Event Position
代表它移动的所有时间。或者我可以有一个Behaviour Position
代表它在任何时候都在哪里。通常我会认为该对象是having始终处于一个位置,所以Behaviour
是一个更好的概念契合。
另一个地方Behaviour
s 用于表示程序可以进行的外部观察,您只能检查“当前”值(因为外部系统在发生更改时不会通知您)。
例如,假设您的程序必须密切关注温度传感器,并避免在温度过高时启动作业。与Event Temperature
我将预先决定轮询温度传感器的频率(或响应什么)。然后遇到与我的其他示例中相同的问题,即必须手动执行某些操作以使最后的温度读数可供决定是否开始工作的事件使用。或者我可以使用fromPoll
做一个Behaviour Temperature
。现在我得到了一个代表温度随时间变化的值的值,并且我已经完全摆脱了对传感器的轮询; Reactive Banana 本身会根据需要尽可能频繁地轮询传感器,而我根本不需要为此考虑任何逻辑!