Java 设计模式——观察者模式:从优衣库不使用新疆棉事件看系统的动态响应

简介: 【11月更文挑战第17天】观察者模式是一种行为设计模式,定义了一对多的依赖关系,使多个观察者对象能直接监听并响应某一主题对象的状态变化。本文介绍了观察者模式的基本概念、商业系统中的应用实例,如优衣库事件中各相关方的动态响应,以及模式的优势和实际系统设计中的应用建议,包括事件驱动架构和消息队列的使用。
  1. 观察者模式概述
  • 观察者模式是一种行为设计模式,它定义了对象之间的一对多依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都会得到通知并自动更新。在这个模式中,有两个主要角色:主题(Subject)和观察者(Observer)。主题是被观察的对象,它维护了一个观察者列表,并提供了用于添加、删除和通知观察者的方法。观察者是关注主题状态变化的对象,它们实现了一个更新接口,当主题状态改变时,主题会调用观察者的更新方法。
  • 例如,在一个简单的天气监测系统中,气象站是主题,它负责收集天气数据。而显示天气信息的各种设备(如手机应用、电子显示屏等)是观察者。当气象站更新天气数据(如温度、湿度等)时,所有的观察者设备都会收到通知并更新显示的天气信息。
  1. 事件背景与系统类比
  • 优衣库事件引发的市场反应类比
  • 在优衣库不使用新疆棉事件中,优衣库的这种行为可以看作是主题状态的改变。消费者群体、相关的供应商、竞争对手等可以看作是观察者。
  • 消费者(观察者)对优衣库的这种行为做出了反应,比如抵制购买优衣库的产品。从系统角度来看,这就相当于观察者接收到主题(优衣库品牌行为)状态改变的信号后,执行了相应的 “更新” 操作(改变购买行为)。
  • 供应商(观察者)可能会重新评估与优衣库的合作关系。这类似于在软件系统中,当主题状态改变时,观察者(供应商系统)根据新的情况更新自己的业务逻辑(如调整供货量或者终止合作)。
  • 在商业系统中的动态响应机制与观察者模式相似性
  • 商业系统中存在许多类似的动态响应场景,都可以用观察者模式来理解。例如,当一家公司(主题)发布了新产品或者改变了价格策略,其合作伙伴(如经销商、物流公司等观察者)和消费者(观察者)都会做出相应的反应。这些反应是基于对主题状态变化的感知,就像在观察者模式中,观察者对主题状态变化做出更新操作一样。
  1. 观察者模式的优势体现
  • 解耦主体和观察者
  • 在事件响应中,就像商业系统中的各个参与方不需要紧密耦合一样。以优衣库事件为例,消费者、供应商等各方的行为(观察者)和优衣库的品牌决策(主题)如果是硬编码在一起,那么系统将非常复杂且难以维护。而观察者模式使得这些观察者和主题之间是松耦合的关系。主题不需要知道观察者的具体细节,只需要在状态改变时通知它们。
  • 例如,在软件系统中,如果一个模块(主题)的内部逻辑发生变化,只要它通知观察者的接口不变,观察者(其他模块)就不需要进行大量的修改。这就好比在优衣库事件中,即使优衣库内部的品牌战略调整方式(主题内部逻辑)发生变化,消费者(观察者)的抵制行为逻辑(如通过社交媒体发声、改变购买习惯等)可以独立于优衣库的内部变化而存在,双方的关系通过一个简单的 “通知 - 响应” 机制(类似于观察者模式的通知和更新接口)来维持。
  • 易于扩展和维护
  • 当新的观察者加入时,在观察者模式下,只需要将新的观察者注册到主题中。就像在商业环境中,如果出现新的市场监督机构(新观察者)关注优衣库这类品牌的行为,它可以很容易地加入到这个 “观察系统” 中。
  • 从软件系统角度看,例如在一个电商系统中,新的促销活动提醒模块(新观察者)可以很容易地添加到关注商品价格变化(主题)的观察者列表中。对于维护来说,当主题或者观察者的业务逻辑发生变化时,只需要修改对应的主题或观察者内部的代码,而不会影响到其他部分的代码。这就好比在优衣库事件后,如果消费者的抵制方式发生变化(观察者逻辑改变)或者优衣库调整品牌形象修复策略(主题逻辑改变),这些修改可以相对独立地进行。
  1. 实际系统设计中的应用建议
  • 事件驱动架构借鉴
  • 在设计类似的具有动态响应需求的系统时,可以借鉴事件驱动架构,而观察者模式是事件驱动架构的一个基础模式。例如,在一个大型的电商平台中,可以将商品价格变化、库存变化等作为事件(主题状态变化),而订单系统、推荐系统等作为观察者。
  • 当商品价格下降(主题状态改变)时,订单系统可以根据新价格生成新的订单,推荐系统可以将该商品推荐给更多用户。通过这种方式,系统的各个部分可以根据事件的发生灵活地做出反应,就像在优衣库事件中,各个相关方根据品牌行为变化做出反应一样。
  • 消息队列的应用
  • 为了更好地实现观察者模式的通知机制,可以使用消息队列。消息队列可以作为主题和观察者之间的通信媒介,确保消息的可靠传递。例如,在一个金融系统中,当股票价格发生变化(主题状态改变)时,消息队列可以将价格变化消息发送给各个观察者(如交易系统、分析系统等)。
  • 这样可以避免因为网络波动或者系统繁忙等原因导致的通知丢失,同时也可以对消息进行异步处理,提高系统的整体性能和响应能力,就像在复杂的商业事件响应中,确保各个相关方能够及时、可靠地收到信息并做出响应。
目录
打赏
0
6
6
0
255
分享
相关文章
前端必须掌握的设计模式——观察者模式
观察者模式(Observer Pattern)是一种行为型设计模式,实现了一种订阅机制。它包含两个角色:**观察者**(订阅消息、接收通知并执行操作)和**被观察者**(维护观察者列表、发送通知)。两者通过一对多的关系实现解耦,当被观察者状态改变时,会通知所有订阅的观察者。例如,商店老板作为被观察者,记录客户的需求并在商品到货时通知他们。前端应用中,如DOM事件注册、MutationObserver等也体现了这一模式。
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。
设计模式:观察者模式
观察者模式属于行为型设计模式,用于建立对象间的一对多依赖关系。当主题(Subject)状态变化时,所有依赖的观察者(Observer)会自动收到通知并更新。
java springboot监听事件和处理事件
通过上述步骤,开发者可以在Spring Boot项目中轻松实现事件的发布和监听。事件机制不仅解耦了业务逻辑,还提高了系统的可维护性和扩展性。掌握这一技术,可以显著提升开发效率和代码质量。
102 33
java springboot监听事件和处理事件
通过上述步骤,开发者可以在Spring Boot项目中轻松实现事件的发布和监听。事件机制不仅解耦了业务逻辑,还提高了系统的可维护性和扩展性。掌握这一技术,可以显著提升开发效率和代码质量。
103 13
|
2月前
|
Java Spring Boot监听事件和处理事件
通过上述步骤,我们可以在Java Spring Boot应用中实现事件的发布和监听。事件驱动模型可以帮助我们实现组件间的松耦合,提升系统的可维护性和可扩展性。无论是处理业务逻辑还是系统事件,Spring Boot的事件机制都提供了强大的支持和灵活性。希望本文能为您的开发工作提供实用的指导和帮助。
132 15
Java Springboot监听事件和处理事件
通过这些内容的详细介绍和实例解析,希望能帮助您深入理解Spring Boot中的事件机制,并在实际开发中灵活应用,提高系统的可维护性和扩展性。
75 7
JAVA内置的观察者模式样本
DisplayElement.java public interface DisplayElement { public void display(); } CurrentConditionsDisplay.
693 0
|
1月前
|
【Java并发】【线程池】带你从0-1入门线程池
欢迎来到我的技术博客!我是一名热爱编程的开发者,梦想是编写高端CRUD应用。2025年我正在沉淀中,博客更新速度加快,期待与你一起成长。 线程池是一种复用线程资源的机制,通过预先创建一定数量的线程并管理其生命周期,避免频繁创建/销毁线程带来的性能开销。它解决了线程创建成本高、资源耗尽风险、响应速度慢和任务执行缺乏管理等问题。
168 60
【Java并发】【线程池】带你从0-1入门线程池
Java网络编程,多线程,IO流综合小项目一一ChatBoxes
**项目介绍**:本项目实现了一个基于TCP协议的C/S架构控制台聊天室,支持局域网内多客户端同时聊天。用户需注册并登录,用户名唯一,密码格式为字母开头加纯数字。登录后可实时聊天,服务端负责验证用户信息并转发消息。 **项目亮点**: - **C/S架构**:客户端与服务端通过TCP连接通信。 - **多线程**:采用多线程处理多个客户端的并发请求,确保实时交互。 - **IO流**:使用BufferedReader和BufferedWriter进行数据传输,确保高效稳定的通信。 - **线程安全**:通过同步代码块和锁机制保证共享数据的安全性。
72 23
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等