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

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位