响应式编程(Reactive Programming 或称反应式编程)是一种流行的编程方法,编写代码是基于对变化的反应。它的灵感来自于我们的日常生活,也即我们如何采取行动以及与他人沟通。
我们在执行日常生活活动时,我们会尽可能多任务,但大脑无法处理多任务,不管我们如何努力去做。我们人类实现多任务的唯一办法是在时间线上在任务之间切换。事实上,我们总是切换任务,即使我们没有意识到它。
例如,要执行一个任务:在星巴克喝一杯咖啡饮料,你需要发出一个命令,等待它准备好,然后接受你的饮料。当你在等待的时候,你很可能会找到别的事情做。这是最简单的执行任务的反应(响应)形式,你会在你等待来自咖啡师的“响应”时做别的事情,当你的咖啡已经准备好后,会叫你的名字时。
响应编程能够简化编程,它依赖于事件,代码运行的顺序不是代码行的顺序,而是和一个以上的事件有关,这些事件发生是以随着时间的推移的序列。我们把这一系列事件称为“流”。
何为事件?例如,你知道某个名人总是在发送有趣微博,每次他推发一条微博我们可以称之为一个“事件”。如果你看看这位名人微博系列,你会发现其实是一个随着时间的推移(一系列的事件)发生的一序列的“事件”。
响应式编程就是因为我们得“响应”这些事件而得以命名。例如,想象一下,你在等待某人发送一个很酷商品的促销码,当这条促销码发出时,你会立即响应,去购买这个很酷的商品。这正是什么响应性编程的原理。
为了能够对事件作出反应,我们必须要监督它。 如果我们没有监听的情况下,我们永远不会知道什么时候它会有事件反应。 在微博上,可以设置监测微博的事件,我们遵循简并设置我们的电话,每次她发微博事件时就会第一时间通知我们。
在响应式编程中,监视事件被称为侦听或订阅该事件。 这一点其实很相似订阅简讯。 当您订阅Web上发布的新闻,您得提供您的电子邮件地址,每次有新的时事通讯时候,您的电子邮件地址将得到该新闻的一个副本。 同样,我们使用某个函数订阅事件流,每当有一个新的事件时,流将激活这个函数,以使我们的代码能够对事件作出响应。 在这个比喻中,新闻通讯平台是事件流,电子报的每一个新闻是一个事件,你的电子邮件是您使用订阅事件流的函数。
现在想象一个动态的通讯,您可以选择主题,并只会发送匹配主题的新闻项目。 你可根据自己的喜好过滤的通讯新闻,而这一点我们可以在事件流做的一样好。 想像你已经使用不同的电子邮件地址订阅多个通讯,以及后来决定你想要的通讯的所有新闻发送到一个新的单电子邮件地址。 简单可以做的是设置通讯新闻发送到新的电子邮件地址的转发邮件规则。 我们可以用事件流同样做到。
将事件流可以和通常数组比较。 他们其实很相似。 数组是在空间值的序列,而事件流是随时间的值的序列。 在响应式编程中,所有函数操作都可以针对一个数组阵列上 - 比如过滤,reduce,mapping,结合,管道 - 也可以在事件流完成! 我们可以过滤的事件流,reduce合并事件流的值,将事件流映射到另一个另外一个,结合组合事件流,将一个流的输入输出到另一个。
----- (转载)