JAVA RMI 文档中文(二)

2024-05-01 00:58
文章标签 java 文档 中文 rmi

本文主要是介绍JAVA RMI 文档中文(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2.6 远端方法调用时的参数传递

一个远端对象只要可以序列化就可以是方法参数或是返回值。这就包括了基础对象、远端对象和实现了java.io.Serializable的非远端对象。更多关于如何序列化类的信息科一参考 “Java Object Serialization Specification”。这些参数或者返回值不是本地的,它们是通过RMI系统动态下载的。更多细节查看Dynamic Class Loading

2.6.1 传递非远端对象

一个非远端对象,无论是作为参数还是返回值,它都是通过复制来传递的,也就是通过java的序列化机制序列化后得到的。

所以,在方法调用过程中,当一个远端对象作为参数或者返回值被传递时,这个非远端对象的内容会在方法调用前被复制。

当调用远端方法返回一个非远端对象时,本地虚拟机就会创建一个新的对象。

2.6.2 传递远端对象

当传递一个远端对象时,实际传递的是这个对象的存根(stub)。
没有暴露的远端对象不会被存根实例替代。远端对象只有实现了远端接口才可以作为参数被传递。

2.6.3 引用的完整性(Referential Integrity)

如果一个对象的两个引用作为一个远端方法的参数从一个虚拟机传递到另一个虚拟机,那么这些引用在发送对象的虚拟机中指向的是同一个对象,它们在接收对象的虚拟机中指向的是同一个对象的副本,RMI系统会在对象传递过程中保证引用的完整性。

2.6.4 类注释(Class Annotation)

当一个对象通过方法调用,从一个虚拟机传递到另一个虚拟机时,RMI系统会通过URL来标识这个类,以便可以在接收端加载这个类。这个要求保证类会按需下载。
(这里翻译的感觉有点问题,下面是原文)

When an object is sent from one JVM to another in a remote method call, the RMI system annotates the class descriptor in the call stream with information (the URL) of the class so that the class can be loaded at the receiver. It is a requirement that classes be downloaded on demand during remote method invocation.

2.6.5 参数传递

在RMI调用中参数被写到流中,该流是java.io.ObjectOutputStream的子类,这样是为了可以将参数序列化到远端调用虚拟机中。ObjectOutputStream子类会重写replaceObject方法,该方法用每一个暴露的远端对象所对应的存根实例来替换他们。参数这些对象是通过ObjectOutputStreamwriteObject方法来写入流中的。ObjectOutputStream会为每一个通过writeObject方法写入流的对象调用replaceObject方法(包括写入对象所引用的对象)。replaceObject方法返回结果如下:
1、如果这个对象实现了java.rmi.Remote而且这个对象在RMI运行时被导出,那么该方法返回这个对象的存根实例。如果这个对象实现了java.rmi.Remote,但是没有在RMI运行时被导出,那么replaceObject方法返回该对象本身。对于远端对象的存根,可以通过调用java.rmi.server.RemoteObjecttoStub方法获得。
2、如果这个对象不是一个java.rmi.Remote的实例,那么会简单返回该对象。

RMI中ObjectOutputStream的子类也会实现annotateClass方法,该类会通过远端类的位置来对类进行解释说明,以便该类可以在接收端被下载。

因为参数写入是通过一个单独的ObjectOutputStream,所以同一个对象的引用在接收端会指向同一个对象的副本。在接收端,参数通过一个单独的ObjectInputStream读出来。

ObjectOutputStream的其他任何写对象的行为(ObjectInputStream的读取对象和它类似)都是在参数传递中维护的。比如说,在写对象是会调用writeReplace方法,在读对象的时候回调用readResolve方法,这些方法都是由RMI参数的编排或者反编排流提供的。

返回值和异常的传递和上面讲的参数传递类似。

这篇关于JAVA RMI 文档中文(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/950346

相关文章

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为