使用远程方法调用:Java ME中的分布式编程
1 理解Java RMI
Java编程语言的一个关键特性是其支持分布式编程——即应用程序可以在不同的主机上运行,通过Java RMI范式来回传递对象。所有分布式面向对象应用程序需要执行三种类型的任务:
- 远程对象发现 :应用程序需要机制来发现对远程对象的引用。
- 远程通信 :运行在不同机器上不同上下文中的应用程序需要能够就对象状态的变化进行通信。
- 远程行为定义 :应用程序还必须能够就那些对象的定义进行通信。
Java RMI通过提供远程发现注册表和为交换Java类和对象的信息提供健壮的通信机制,满足分布式程序的两个关键需求。图1展示了基于RMI的应用程序中客户端和服务器之间的关系。
graph LR
A[客户端] -- "RMI调用" --> B[RMI注册表]
B -- "对象引用" --> C[远程对象]
C -- "方法调用" --> D[远程方法实现]
D -- "返回结果" --> C
C -- "返回结果" --> A
2 Java RMI架构
基于RMI的解决方案