0

0

什么是Java中的协作式设计_对象之间通过消息传递进行通信

P粉602998670

P粉602998670

发布时间:2026-02-25 17:27:12

|

403人浏览过

|

来源于php中文网

原创

java中对象“说话”本质是通过接口定义消息协议实现松耦合协作,而非简单方法调用;关键在于依赖抽象、运行时注入、明确契约(如null/异常/线程安全约定),避免observer等伪解耦。

什么是java中的协作式设计_对象之间通过消息传递进行通信

Java里对象怎么“说话”:消息传递不是调用方法那么简单

Java没有原生的“消息传递”机制——所谓协作式设计里的“发送消息”,实际就是方法调用,但关键在**谁调用、何时调用、依赖是否显式暴露**。很多人误以为加个 notify() 或用 Observer 就算消息传递,其实那只是特定场景的实现,不是设计本质。

真正的协作式设计,核心是让对象只关心“能接收什么消息”,不关心“对方是谁、怎么实现”。这靠接口和松耦合达成,不是靠语法糖。

怎么写出有消息感的对象:用接口定义“协议”,而非直接 new 实例

常见错误是 A 类直接 new B(),然后调用 b.doSomething()——这叫强依赖,不是协作。A 无法替换 B 的实现,也无法在运行时切换行为。

  • B 的能力抽象成接口,比如 PaymentProcessor
  • A 类只持有 PaymentProcessor 引用,不关心具体是 AlipayProcessor 还是 WechatProcessor
  • 构造或方法参数注入实现类,而不是自己创建——这就是“消息接收方可插拔”的基础

示例:

public class OrderService {
    private final PaymentProcessor processor; // ← 只认“协议”
    public OrderService(PaymentProcessor processor) {
        this.processor = processor; // ← 消息接收方由外部决定
    }
    public void checkout() {
        processor.process(); // ← 这才是“发消息”:我不知你怎么做,只知你能做
    }
}

为什么不用 Observer / EventListener 就不是协作式设计?

java.util.Observer 或自定义事件总线,容易陷入“伪解耦”:监听器仍需注册到具体被观察对象,且事件类型常是具体类(如 OrderCreatedEvent),导致上下游隐式绑定。

立即学习Java免费学习笔记(深入)”;

行盟APP1.0 php版
行盟APP1.0 php版

行盟APP是结合了通信和互联网的优势,加之云计算所拥有的强大信息资源,借助广大的终端传递服务,潜在的拥有巨大商机。她到底是什么,又有什么作用?她是一款手机应用软件;她是一款专门为企业服务的手机应用软件;她是一款能够将企业各种信息放入其中并进行推广传播的手机应用软件!只要轻轻一点,企业的简介,产品信息以及其他优势就能最快最大限度的透过手机展现在客户的眼前,一部手机,一个APP,你面对的将是一个6亿&

下载

真正轻量的消息协作,推荐更克制的做法:

  • 优先用回调函数(Consumer<result></result>BiFunction<...></...>)传入行为,避免引入事件生命周期管理
  • 若必须异步通知,用 CompletableFuture 链式传递结果,比手动维护 listener 列表更清晰
  • 警惕 Spring 的 @EventListener:它让监听逻辑散落在各处,调用链路不可见,调试时容易丢失“谁在响应哪条消息”

容易被忽略的边界:null 值、异常、线程安全不是“消息协议”的一部分

协作式设计默认假设消息接收方能处理输入。但 Java 不强制校验 null、不声明受检异常、也不保证方法线程安全——这些都得靠协作双方私下约定,否则“发消息”就变成“扔炸弹”。

实操建议:

  • 接口方法文档里明确写清 @param 是否允许 null,比如 process(@NonNull String orderId)
  • Optional<t></t> 表达“可能无响应”,比返回 null 更符合消息语义
  • 如果消息需跨线程(如 UI 更新),接收方必须自行处理同步,发送方不应假设 SwingUtilities.invokeLater 已包裹

消息能发出去,不等于对方收到了;对方收到了,也不等于它能正确处理。协议之外的细节,最容易在联调时突然冒出来。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
spring框架介绍
spring框架介绍

本专题整合了spring框架相关内容,想了解更多详细内容,请阅读专题下面的文章。

144

2025.08.06

Java Spring Security 与认证授权
Java Spring Security 与认证授权

本专题系统讲解 Java Spring Security 框架在认证与授权中的应用,涵盖用户身份验证、权限控制、JWT与OAuth2实现、跨站请求伪造(CSRF)防护、会话管理与安全漏洞防范。通过实际项目案例,帮助学习者掌握如何 使用 Spring Security 实现高安全性认证与授权机制,提升 Web 应用的安全性与用户数据保护。

81

2026.01.26

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

246

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

886

2024.03.01

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1653

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

506

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2308

2025.12.29

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

127

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 10.2万人学习

Java 教程
Java 教程

共578课时 | 72.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号