5.2 模块之间的交互和通信方式方法总结

news2024/12/28 20:25:03

在这里插入图片描述

事件驱动通信:

事件驱动通信是一种通信模式,它基于事件的发生和相应来进行通信。在事件驱动通信中,各个组件之间通过发送事件来进行通信,而不是直接调用对方的方法。

事件驱动通信的基本原理是,当一个组件发生某个特定的事件时,它会发送一个事件消息,然后其他相关的组件可以监听并相应这个事件消息。这种通信模式的好处是,各个组件之间解耦合,不需要直接依赖对方的接口或实现,而是通过事件来进行通信。这样可以增加系统的灵活性和可扩展性。

事件驱动通信可以在各种不同的系统中使用,包括软件系统、硬件系统等。在软件系统中,常见的应用场景包括GUI编程、服务器编程、消息队列等。在硬件系统中,常见的应用场景包括传感器网络、物联网等。

常见的事件驱动通信方式包括观察者模式、发布-订阅模式、消息队列等。观察者模式是一种基于订阅-发布的方式,其中一个组件充当观察者,监听某个事件的发生;另一个组件充当主题,负责发布事件。发布-订阅模式是一种基于主题-订阅的方式,其中一个组件充当发布者,负责发布事件;另一个组件充当订阅者,监听并相应事件。消息队列是一种通过消息传递的方式进行通信,其中各个组件通过发送和接收消息来进行通信。

总而言之,事件驱动通信是一种通过事件消息来进行通信的模式,可以增加系统的灵活性和可扩展性。它在各种不同的系统中都有广泛的应用。

消息队列通信:

消息队列通信是一种在软件系统中实现异步通信的方式。消息队列允许发送者将消息发送到队列中,而接收者则从队列中接收消息。这种通信方式解耦了发送者和接收者,使它们能够独立操作。

在消息队列通信中,发送者将消息发送到队列中,而不需要等待接收者立即处理。接收者根据自己的调度和处理能力,从队列中接收消息,并进行处理。这种异步通信方式能够提高系统的吞吐量和响应速度。

消息队列通信可以用于不同进程或不同主机之间的通信。例如,一个系统的前端请求可以通过消息队列发送给后端处理,前端可以立即返回响应给用户,而后端则可以根据自己的负载情况来处理请求。

常见的消息队列通信工具包括ActiveMQ、RabbitMQ、Kafka等。它们提供了可靠的消息传递、消息持久化、消息路由和消息订阅等功能,能够满足不同场景下的需求。

总而言之,消息队列通信是一种异步通信方式,通过将消息发送到队列中,实现发送者和接收者之间的解耦和并发处理,提高系统的性能和可伸缩性。

共享内存通信:

共享内存通信是一种进程间通信的方式,它允许不同进程之间共享同一块内存区域。在共享内存通信中,多个进程可以直接访问和修改同一块共享内存,从而实现进程间的数据传输和通信。

共享内存通信的优势在于它的高效性和低延迟。由于进程直接访问共享内存区域,无需进行复杂的数据拷贝操作,因此可以避免了因为数据拷贝而引入的性能损耗。同时,由于进程直接访问共享内存,通信的延迟也相对较低,可以快速响应和处理数据。

然而,共享内存通信也存在一些挑战和限制。首先,由于多个进程可以同时访问共享内存,需要采取相应的同步和互斥机制来保证数据的一致性和正确性。其次,共享内存通信需要进程之间具有相同的内存映射,因此通信的双方必须在同一台计算机上运行。最后,共享内存通信对于数据的生命周期管理也存在一定的难度,需要确保在所有进程都完成对共享内存的访问后及时释放。

总结来说,共享内存通信是一种高效的进程间通信方式,适用于需要频繁传输大量数据的场景。但同时也需要付出一定的努力来维护数据的一致性和正确性,并确保良好的内存管理策略。

远程过程调用通信:

远程过程调用(Remote Procedure Call,简称RPC)是一种用于不同机器间通信的技术。它允许一个程序调用另一个机器上的子程序,就像调用本地的子程序一样。RPC能够隐藏底层通信细节,使得程序员能够更方便地编写分布式应用。

在RPC通信中,通常有一个客户端程序和一个服务端程序。客户端通过发送请求消息给服务端来调用服务端的方法,服务端接收到请求后执行相应的方法并返回结果给客户端。客户端和服务端可以在不同的机器上,它们通过网络进行通信。

RPC通信通常涉及以下几个步骤:

1. 客户端向服务端发起请求,包括需要调用的方法名和参数。

2. 服务端接收到请求后通过解析请求消息,确定需要执行的方法,执行该方法,并返回结果给客户端。

3. 客户端接收到结果,并进行相应的处理。

在RPC通信中,必须使用一种通信协议来定义消息的格式和通信的规则。常用的RPC通信协议有XML-RPC、JSON-RPC和SOAP。这些协议定义了消息的结构以及如何序列化和反序列化消息。

RPC通信可以适用于各种场景,例如在分布式系统中,不同节点之间需要进行协作和数据交换;在微服务架构中,各个服务之间需要进行通信和调用。RPC使得不同程序或服务之间能够方便地进行通信,加强了系统的可扩展性和灵活性。

内模块;

依赖注入:

依赖注入是一种设计模式,它可以用来管理对象之间的依赖关系。在依赖注入中,一个对象(被称为依赖)通过构造函数、方法参数或者属性等方式接受它所依赖的其他对象(依赖项)的实例,而不是自己创建和管理这些依赖项。

依赖注入有以下几个优点:

1. 可测试性:通过依赖注入,我们可以轻松地模拟和替换依赖项,从而方便进行单元测试。例如,我们可以使用模拟对象来代替真正的数据库或网络连接等依赖项,使测试更加灵活和可靠。

2. 解耦性:依赖注入可以将对象之间的耦合度降低,使得它们之间的关联更加松散。这样一来,我们可以更容易地修改和替换依赖项,而不需要修改依赖对象本身。

3. 可扩展性:通过依赖注入,我们可以轻松地添加新的依赖项,而不需要修改原有的代码。这样一来,我们可以更加方便地实现功能的扩展和变化。

常见的依赖注入框架有Spring、Guice等。这些框架提供了一些机制和注解,用来简化和管理依赖注入的过程。通过使用这些框架,我们可以更加方便地实现依赖注入,并将关注点集中在业务逻辑上,而不需要过多关注依赖项的创建和管理。

观察者模式:

观察者模式是一种设计模式,用于实现模块之间的通信。在观察者模式中,有两个主要的角色:观察者和主题(或被观察者)。

观察者是一个接口或抽象类,定义了观察者的行为。主题是一个类,维护了观察者的列表,并提供了注册观察者、删除观察者和通知观察者的方法。

当主题发生改变时,它会通知所有注册的观察者。观察者可以根据需要更新自己的状态或执行一些操作。

下面是一个使用观察者模式实现模块通信的示例代码:

```java

// 观察者接口

interface Observer {

void update\(String message\);

}

// 主题类

class Subject {

private List<Observer> observers = new ArrayList<>\(\);

public void registerObserver\(Observer observer\) \{

    observers\.add\(observer\);

\}

public void removeObserver\(Observer observer\) \{

    observers\.remove\(observer\);

\}

public void notifyObservers\(String message\) \{

    for \(Observer observer : observers\) \{

        observer\.update\(message\);

    \}

\}

}

// 具体观察者类

class ConcreteObserver implements Observer {

private String name;

public ConcreteObserver\(String name\) \{

    this\.name = name;

\}

@Override

public void update\(String message\) \{

    System\.out\.println\(name \+ " received message: " \+ message\);

\}

}

// 测试代码

public class Main {

public static void main\(String\[\] args\) \{

    Subject subject = new Subject\(\);

    Observer observer1 = new ConcreteObserver\("Observer 1"\);

    Observer observer2 = new ConcreteObserver\("Observer 2"\);

    Observer observer3 = new ConcreteObserver\("Observer 3"\);

    subject\.registerObserver\(observer1\);

    subject\.registerObserver\(observer2\);

    subject\.registerObserver\(observer3\);

    subject\.notifyObservers\("Hello, observers\!"\);

    subject\.removeObserver\(observer2\);

    subject\.notifyObservers\("Observer 2 removed\."\);

\}

}

```

在上面的示例中,我们定义了一个观察者接口`Observer`,它有一个`update`方法用于接收主题发来的消息。然后,我们定义了一个主题类`Subject`,它维护了观察者列表,并提供了注册、删除和通知观察者的方法。接着,我们实现了一个具体的观察者类`ConcreteObserver`,它实现了`Observer`接口,并在`update`方法中打印收到的消息。

在测试代码中,我们创建了一个主题对象`subject`,并创建了三个观察者对象`observer1`、`observer2`和`observer3`。然后,我们依次注册观察者,并调用`notifyObservers`方法通知观察者。最后,我们删除了观察者`observer2`,并再次调用`notifyObservers`方法。

运行这段代码,可以看到观察者们依次收到了主题发送的消息,并在观察者2被删除后不再收到消息。

使用观察者模式可以实现模块之间的松耦合通信,主题和观察者之间相互独立,可以随时添加或删除观察者,而不需要修改主题的代码。这样一来,当系统中发生改变时,只需要修改相关的主题或观察者的代码即可,而不会影响其他模块。

发布订阅模式:

发布订阅模式是一种常用的通信模式,用于解耦消息的发送者和接收者。在该模式中,消息的发送者称为发布者,而消息的接收者称为订阅者。

发布者负责发布消息,而订阅者则注册自己对某个主题感兴趣,以便接收与该主题相关的消息。当发布者发布与某个主题相关的消息时,订阅者将收到该消息并进行相应的处理。

通过发布订阅模式,可以实现多个消息发送者和接收者之间的解耦,从而提高系统的可扩展性和可维护性。同时,订阅者可以动态地注册和取消注册对某个主题的订阅,从而实现灵活的消息通信。

在实际应用中,发布订阅模式可以通过消息队列、事件总线等方式来实现。常见的应用场景包括系统间消息通信、消息广播等。

8.其他通信方式:

管道通信:

管道通信是一种进程间通信的方式,它通过在进程之间创建管道来实现数据的传输。管道可以被看作是一个字节流,数据可以从一个进程的输出端写入管道,然后从另一个进程的输入端读取。管道是一种半双工的通信方式,即数据只能在一个方向上流动。

在Unix和Linux系统中,使用管道通信可以通过调用pipe()系统函数来创建管道。一般情况下,一个管道有一对文件描述符,一个用于读取数据,另一个用于写入数据。这两个文件描述符可以通过fork()系统调用创建的子进程来共享。

管道通信的特点包括:

1. 管道是一种顺序存取的通信方式,数据按照写入顺序读取;

2. 管道是一种半双工通信方式,即数据只能在一个方向上流动;

3. 管道的容量是有限的,如果管道已满,写入操作将被阻塞,直到有空间可用;

4. 管道是面向字节流的通信方式,不保证数据的边界。

管道通信常用于父子进程之间的通信,父进程将数据写入管道,子进程从管道中读取数据。管道通信也可以通过多个管道连接来实现多个进程之间的通信。

套接字通信

套接字通信是一种在网络中传输数据的技术。它在计算机网络中起到了连接和传输数据的作用。套接字通信使用端口号来识别不同的应用程序,通过网络传输数据。

套接字通信分为两种类型:客户端套接字和服务器套接字。客户端套接字用于发起连接请求和发送数据,而服务器套接字用于接受连接请求和处理客户端的请求。

套接字通信使用TCP协议或UDP协议来传输数据。TCP协议提供可靠的连接,确保数据的完整和顺序性,适用于需要可靠传输的应用程序。UDP协议提供无连接的传输,适用于需要快速传输但对数据完整性要求不高的应用程序。

在套接字通信中,客户端和服务器之间通过套接字进行通信。客户端首先创建一个套接字,并指定服务器的IP地址和端口号。然后客户端发送连接请求给服务器,如果服务器接受连接请求,则建立连接。一旦连接建立,客户端和服务器之间可以互相发送数据。

套接字通信可以用于各种应用程序,如网页浏览器、邮件客户端、文件传输等。它是实现网络通信的重要技术之一。

文件共享通信:

文件共享通信是指通过网络将文件从一台计算机传输到另一台计算机的过程。在文件共享通信中,发送方将文件上传到网络中,接收方通过网络下载文件到本地计算机。

文件共享通信可以通过多种方式实现,包括:

1. 电子邮件附件:发送方将文件作为附件添加到电子邮件中,然后发送给接收方。

2. 文件传输协议(FTP):通过FTP服务器上传和下载文件。

3. 网络共享文件夹:发送方将文件放入网络共享文件夹中,接收方可以通过访问该文件夹来下载文件。

4. 网络云存储:发送方将文件上传到云存储服务(如Google Drive、Dropbox等),接收方可以通过登录云存储服务来下载文件。

文件共享通信在各个领域都有广泛应用,例如企业内部文件共享、团队协作、远程教育等。同时,为了确保文件共享的安全性,通常会采取一些措施,例如设置访问权限、使用加密技术等。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1811938.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

DevExpress Data Grid

WinForms数据网格是一个由DirectX渲染引擎提供支持的高性能UI组件。数据网格&#xff08;GridControl&#xff09;提供了一个灵活的基于视图的体系结构&#xff0c;包括许多数据整形和UI自定义功能。数据网格可以显示和编辑来自任何大小和复杂度的任何数据源的数据。 数据绑定…

【Linux系统】线程与线程控制

本篇博客整理了Linux下线程的概念、线程控制的相关接口&#xff0c;旨在让读者初步认识线程&#xff0c;并为下一篇多线程作铺垫。 目录 一、线程是什么 1.线程是进程的执行流 2.线程的执行、调度、切换 3.页表分级与线程资源分配 4.线程的优缺点 二、线程控制 1.创建…

数据库管理-第201期 优先级事务-01(20240611)

数据库管理201期 2024-06-11 数据库管理-第201期 优先级事务-01&#xff08;20240611&#xff09;1 概念2 使用优先级事务2.1 配置会话优先级2.2 配置系统级别等待目标 2.3 确认自动回滚2.4 配置优先级事务模式2.5 使用优先级事务模式确定系统级等待目标 总结 数据库管理-第201…

北斗高精准定位:电动自行车行业的新引擎

近年来&#xff0c;随着科技的发展与智能化进程的加快&#xff0c;电动自行车行业也迎来了新的变革。毫无疑问&#xff0c;北斗高精度定位技术逐渐成为这一行业的关键突破。本文将详细探讨北斗高精度定位技术在电动自行车行业中的多样应用以及其带来的诸多优势。北斗系统的背景…

解决方案:昇腾aarch64服务器安装CUDA+GCC+CMake,编译安装Pytorch,华为昇腾HPC服务器深度学习环境安装全流程

目录 一、安装CUDA和cudnn1.1、下载CUDA驱动1.2、安装CUDA驱动1.3、配置环境变量1.4、安装cudnn1.5、安装magma-cuda 二、安装gcc编译器三、安装CMake四、安装NCCL五、编译安装Pytorch5.1、前提准备5.2、下载pytorch源码5.3、配置环境变量5.4、Pytorch编译安装5.5、测试Pytorch…

你想考取名牌大学吗?那就按我说的学与做

你想考取名牌大学吗&#xff1f;那就按我说的学与做 我讲的这一秘笈&#xff0c;是自己学生时代就读时的实践体会。 本人并不比别人聪慧&#xff0c;当年也正是凭借这一学习技巧&#xff0c;而获得各科均衡且良好成绩考取大学的。在上世纪八十年代&#xff0c;有多少人能考取…

比起本地渲染,渲染100网渲平台有哪些优势?渲染100邀请码1a12

渲染100是知名的网渲平台&#xff0c;比起本地渲染&#xff0c;它有以下几个优势。 1、价格低 渲染100价格便宜&#xff0c;15分钟2毛60分钟8毛的价格非常适合小图&#xff0c;一张图平均2.1元左右&#xff0c;非常的低了&#xff0c;选择渲染100可以节省成本。2、速度快 渲染…

STM32移植Easylogger输出

简介 EasyLogger 是一款超轻量级 、高性能的 C 日志库&#xff0c;非常适合对资源敏感的软件项目&#xff0c;例如&#xff1a;IoT 产品、可穿戴设备、智能家居等等。相比 log4c、zlog 这些知名的 C 日志库&#xff0c;EasyLogger 的功能更加简单&#xff0c;提供给用户的接口…

20240611在飞凌OK3588-C核心板的Linux系统下打通UART0和UART3

20240611在飞凌OK3588-C核心板的Linux系统下打通UART0和UART3 2024/6/11 7:45 Z:\OK3588_Linux_fs\kernel\arch\arm64\boot\dts\rockchip\OK3588-C-common.dtsi &pinctrl { m2 { net_m2_rst_gpio: net_m2_rst_gpio { rockchip,pins <1 RK_PC6 RK_…

轻松掌握两种方法,教你jpg图片怎么改大小kb

在数字时代&#xff0c;我们经常需要在网络上传、分享或存储图片&#xff0c;而其中一项常见的挑战就是将图片的文件大小调整到符合特定要求。对于JPEG格式的图片&#xff0c;改变其大小&#xff08;以KB为单位&#xff09;是一种常见的需求&#xff0c;特别是在网络上传限制或…

国产Sora真的来了!免费体验!实测快手可灵Kling文生视频大模型(附申请方法)

文章首发于公众号&#xff1a;X小鹿AI副业 大家好&#xff0c;我是程序员X小鹿&#xff0c;前互联网大厂程序员&#xff0c;自由职业2年&#xff0c;也一名 AIGC 爱好者&#xff0c;持续分享更多前沿的「AI 工具」和「AI副业玩法」&#xff0c;欢迎一起交流~ 自从年初&#xff…

基于STM32开发的智能鱼缸控制系统

目录 引言环境准备智能鱼缸控制系统基础代码实现&#xff1a;实现智能鱼缸控制系统 4.1 水温传感器数据读取4.2 水泵与加热器控制4.3 水位传感器数据读取4.4 用户界面与数据可视化应用场景&#xff1a;水族箱管理与优化问题解决方案与优化收尾与总结 1. 引言 智能鱼缸控制系…

iOS18首个Beta测试版发布,功能介绍附beta升级办法!

今天凌晨&#xff0c;一年一度的苹果WWDC24开发者大会正式开幕&#xff0c;发布了iOS 18、iPadOS 18、macOS Sequoia、watch OS11等新系统。 大会结束后&#xff0c;苹果火速发布了首个iOS 18开发者Beta版&#xff0c;目前有开发者资格的用户已经可以下载体验尝鲜了。 本次更新…

SpringSecurity入门(二)

8、获取用户认证信息 三种策略模式&#xff0c;调整通过修改VM options // 如果没有设置自定义的策略&#xff0c;就采用MODE_THREADLOCAL模式 public static final String MODE_THREADLOCAL "MODE_THREADLOCAL"; // 采用InheritableThreadLocal&#xff0c;它是Th…

VSFTP本地用户访问-设置

1、本地用户基本配置档设置如下 vim /etc/vsftpd/vstfpd.conf local_enableYES -------允许本地用户登陆 write_enableYES -----允许执行FTP命令&#xff0c;如果禁用&#xff0c;将不能进行上传、下载、删除、重命名等操作 local_umask022 ---------本地用户上传umask值…

公用nacos,实现只调用本机相应服务,不出现负载均衡到别人机器上

当我们有两个研发同时在调试一个微服务模块时&#xff0c;你和对方本地都会启动服务&#xff0c;这就导致在nacos会同时注册两个实例。默认情况下请求这个服务&#xff0c;具体处理请求的程序会在你和对方之间来回轮询&#xff0c;即一下你的服务一下对方的服务。 其结果就导…

重学java 66.IO流 转换流

且敬我疯狂&#xff0c;生命中不败的篇章 —— 24.6.11 一、字符编码 计算机中储存的信息都是用二进制数表示的&#xff0c;而我们在屏幕上看到的数字、英文、标点符号、汉字等字符是二进制数转换之后的结果。[按照某种规则&#xff0c;将字符存储到计算机中&#xff0c;称为编…

10_3、C++继承与派生:派生类成员访问

派生类成员访问 作用域分辨符虚基类概念及用法虚基类派生类的构造函数 赋值兼容规则 作用域分辨符 如果派生类中存在和基类中完全相同的函数&#xff0c;将发生同名覆盖。如果在派生类中存在一个和基类某数据成员同名的数据成员&#xff0c;或者和基类某成员函数的名称和参数表…

采用PHP语言(医院安全不良事件上报系统源码)医院不良事件 各类事件分析、分类、处理流程

医疗安全不容忽视&#xff01; 医疗安全&#xff08;不良&#xff09;事件是指在临床诊疗活动中以及医院运行过程中&#xff0c;任何可能影响患者的诊疗结果、增加患者的痛苦和负担并可能引发医疗纠纷或医疗事故&#xff0c;以及影响医疗工作的正常运行和医务人员人身安全的因…

我给KTV服务生讲解防抖,他竟然听懂了

端午节三天假期&#xff0c;的最后一天&#xff0c;我和朋友闲来无事&#xff0c;想着去唱会儿歌吧&#xff0c;好久不唱了&#xff0c;于是吃了午饭&#xff0c;石景山就近找了一家KTV&#xff0c;我们团好了卷就过去了。 装修还算不错&#xff0c;很快找到服务生&#xff0c…