JAVA RMI文档中文

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

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

原文链接
2.4 RMI 接口和类概述
负责rmi系统远程调用使用的类和接口都定义在 java.mri包中。下图展示了这些接口和类之间大概的关系:
这里写图片描述

2.4.1 java.rmi.Remote 接口
在RMI中,一个remote接口会声明一系列的方法,这些方法可能会被一个远端的java虚拟机调用。一个远端接口必须满足下列条件:
1、一个远端接口必须直接或间接实现java.rmi.Remote接口。
2、远端接口中声明的方法必须满足下列条件:
1、一个远端方法声明的时候,除了自身需要抛出的异常,必须要抛出java.rmi.RemoteException(或者它的父类,比如java.io.IOException, java.lang.Exception)。
2、在远端方法声明中,远端对象声明为参数或返回值(在参数列表中直接声明或在参数中嵌入非远端对象)的远端对象必须声明为远端接口,而不是该接口的实现类。

java.rmi.Remote 接口是一个marker interface,它没有声明方法。

一个远端接口必须至少实现java.rmi.Remote接口。但是,在下面情况下,一个远端接口也可以实现一个非远端接口:
一个远端接口可能实现一个非远端接口,只要这个接口下的方法全部满足远端接口下方法的声明条件。

比如,下面的接口BankAccount 定义了一个用来访问银行账户的远端接口。它包含了存钱、获取余额和撤回方法。

public interface BankAccount extends java.rmi.Remote {public void deposit(float amount)throws java.rmi.RemoteException;public void withdraw(float amount)throws OverdrawnException, java.rmi.RemoteException;public float getBalance()throws java.rmi.RemoteException;
}

接下来的例子,展示了一个有效的远端接口Beta,它实现了一个远端接口java.rmi.Remote和一个非远端接口Alpha,该接口声明了一些远端方法。

public interface Alpha {public final String okay = "constants are okay too";public Object foo(Object obj)throws java.rmi.RemoteException;public void bar() throws java.io.IOException;public int baz() throws java.lang.Exception;
}public interface Beta extends Alpha, java.rmi.Remote {public void ping() throws java.rmi.RemoteException;
}

2.4.2 RemoteException
java.rmi.RemoteException是RMI系统在运行时,方法调用时抛出异常的父类。为了保证使用RMI系统的应用的健壮性,每一个远端方法在声明的时候都必须抛出该异常。

该异常在某些原因下当方法调用异常会被抛出。这些原因包括:
1、连接失败(远端服务器不可达到或者拒绝连接,服务端关闭连接等)
2、参数或者返回值编组或者解组错误(Failure during parameter or return value marshalling or unmarshalling)
3、协议错误
EemoteException 是一个检查性异常(它必须被调用者处理,而且会受到编译器检查),而不是一个运行时异常。

2.4.3 RemoteObject 类和它的子类
RMI服务中的功能是由java.rmi.server.RemoteObject和它的子类以及java.rmi.server.RemoteServerjava.rmi.server.UnicastRemoteObjectjava.rmi.activation.Activatable提供的。

1、java.rmi.server.RemoteObject类实现了java.lang.Object中的hashCode、equals和toString方法,这些方法对于远端对象也是很有用的。

2、UnicastRemoteObjectActivatable 提供了创建远端对象的方法,并暴露它们给客户端,供客户端使用。

3、java.rmi.server.UnicastRemoteObject类定义了一个单例(unicast)远端对象,该对象的引用只有在服务端进程有效的时候才会有效。

4、java.rmi.activation.Activatable是一个抽象类,它定义了一个远端对象activatable,当它的方法被调用的时候,它就开始执行,并且可以在必要的时候停止。

2.5 实现一个远端接口

一个类实现一个远端接口,通常要遵守下面的规则:
1、这个类通常会继承java.rmi.server.UnicastRemoteObject,从而继承java.rmi.server.RemoteObjectjava.rmi.server.RemoteServer提供的方法。
2、这个类可以实现任意多的远端接口。
3、这个类可以继承其他的远端接口实现类。
4、这个类可以定义不在远端接口中出现的方法,当时该方法只能用于本地。

比如说,下面这个类BankAcctImpl实现了BankAccount远端接口,而且继承了java.rmi.server.UnicastRemoteObject类:

package mypackage;import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;public class BankAccountImplextends UnicastRemoteObjectimplements BankAccount
{private float balance = 0.0;public BankAccountImpl(float initialBalance) throws RemoteException {balance = initialBalance;}public void deposit(float amount) throws RemoteException {...}public void withdraw(float amount) throws OverdrawnException,RemoteException {...}public float getBalance() throws RemoteException {...}
}

注意,如果有必要的话,一个实现了远端接口的类可以继承除了java.rmi.server.UnicastRemoteObject外的其他类。但是,这个实现类必须承担暴露这些对象的(由UnicastRemoteObject的构造方法负责)而且要实现(如果需要的话)正确的hashCodeequalstoString这些从java.lang.Object继承来的方法。

To Be Continue

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



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

相关文章

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Springboot整合Redis主从实践

《Springboot整合Redis主从实践》:本文主要介绍Springboot整合Redis主从的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言原配置现配置测试LettuceConnectionFactory.setShareNativeConnect

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma