黑板模式是一种常用的架构模式,是观察者模式的一个扩展,应用中的多种不同数据处理逻辑相互影响和协同来完成数据分析处理。允许消息的读写同时进行,广泛地交互消息。就好像多位不同的专家在同一黑板上交流思想,每个专家都可以获得别的专家写在黑板上的信息,同时也可以用自己的分析去更新黑板上的信息,从而影响其它专家。比如A观察了B、C、D、E、F这么多个对象,按照观察者模式,当B、C、D、E、F中某个对象状态改变时,通过初始化一个A对象然后利用A对象去调用operation操作。但是在黑板模式中是这样,B、C、D、E、F一旦状态改变,它会将其记录在一个类似黑板的统一中央数据中,然后A对象只需从黑板上关注自己的观察对象状态是否发生改变,一旦有改变则调用operation()操作。

 

  

黑板架构设计 黑板架子的安装步骤_java

 

  黑板模式一般不会对架构产生什么影响,但它通常会要求有一个清晰的消息结构。黑板模式一般都会提供一系列的过滤器,以便消息的消费者不再接触到与自己无关的消息。在实际开发中,黑板模式常见的有两种实现方式:

  数据库作为黑板

  利用数据库充当黑板,生产者更新数据信息,不同的消费者共享数据库中信息,这是最常见的实现方式。该方式在技术上容易实现,开发量较少,熟悉度较高。缺点是在大量消息和高频率访问的情况下,性能会受到一定影响。在该模式下,消息的读取是通过消费者主动“拉取”,因此该模式也叫做“拉模式”。



  优点:便于实现信息的查询,筛选和统计,这方面关系数据库提供了SQL 92的强大支持。



  缺点:不能用于较高实时性要求的环境,这种实现是工作在“拉模式”下的,并且高频率的访问数据库会导致严重的系统性能问题。



  消息队列作为黑板

  以消息队列作为黑板,通过订阅-发布模型即可实现黑板模式。这也是黑板模式被淡忘的一个重要原因:消息队列(Message Queue)已经非常普及了,做Java开发的已经没有几个不知道消息队列的。在该模式下,消费者接收到的消息是被主动推送过来的,因此该模式也称为“推模式”。

  优点:可以有效应用于实时性要求较高的系统,这种实现工作在“推模式”下。



  缺点:难于实现信息的统计分析,不像实现方式一那样可以通过SQL支持,这些工作必须开发者自己完成。




  典型应用:信号处理领域,数据库,人工智能系统,如网络信息检索、电子商务、自动控制、办公自动化、商业管理智能决策、语音和模式识别、智能控制领域等



  介绍一下语音识别的例子:



  语音识别黑板里边就是语言包 ;语言包就是知识源,控制机构就是管理语言包的,当你说一句话,不知道是什么语言,所以时非确定性的问题,控制机构把你说的话对应的语言包给你看,这就是黑板模式的流程