设计模式——黑板模式

黑板模式

黑板模式(Blackboard Design Pattern)是观察者模式的一个扩展允许消息的读写同时进行,广泛地交互消息。

黑板模式允许多个消息读写者同时存在,消息的生产者和消费者完全分开,两者在空间和时间上可以解耦,并且互不干扰。

设计模式——黑板模式_第1张图片

黑板模式是消息的广播,主要解决消息的生产者和消费者之间的耦合问题,核心是消息存储(黑板),它存储所有消息,并可以随时被读取。当然,消息的写入者也可以变身为消息的阅读者,读写者在时间上解耦。对于这些消息,消费者只需要关注特定消息,不处理与自己不相关的消息,这一点通常通过过滤器来实现。


黑板模式的实现方式

黑板模式常见的有两种实现方式:数据库作为黑板消息队列作为黑板

(1)数据库作为黑板

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

在该模式下,消息的读取是通过消费者主动“拉取”,因此该模式也叫做“拉模式”。

(2)消息队列作为黑板

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

你可能感兴趣的:(设计模式)