活动介绍

CORBA技术:工厂对象、对象持久化与RMI-IIOP详解

立即解锁
发布时间: 2025-08-17 02:29:09 阅读量: 2 订阅数: 7
PDF

Java网络编程与文件处理入门

### CORBA 技术:工厂对象、对象持久化与 RMI - IIOP 详解 #### 1. 使用工厂对象 在实际应用中,客户端程序常常需要创建 CORBA 对象,而不仅仅是使用已经设置好的对象。实现这一目的的唯一途径是通过 ORB 上已发布的工厂对象接口。对于每种需要创建的对象类型,必须在 IDL 规范(在 ORB 上)中定义一个工厂对象接口,并在服务器上实现该接口。 通常,此类接口的命名约定是在要创建的对象类型名称后面添加“Factory”一词。例如,`Account` 接口的对象将由 `AccountFactory` 对象创建。`AccountFactory` 对象包含一个创建方法,允许连接的客户端创建 `Account` 对象。这个创建方法的名称可以任意指定,但为了方便起见,通常在要创建的对象类型前面加上“create”。因此,`AccountFactory` 的创建方法可以命名为 `createAccount`。 假设 `Account` 对象在创建时只需要一个账号和账户名称,那么 IDL 规范中的 `AccountFactory` 接口如下: ```java interface AccountFactory { Account createAccount(in long acctNum, in string acctName); }; ``` 该方法的实现将使用 `new` 运算符来创建 `Account` 对象。与其他接口实现一样,此实现必须扩展由 `idlj` 生成的适当的 `ImplBase` 类(在这种情况下是 `_AccountFactoryImplBase`)。按照在实现类名称后面添加“Servant”的约定,我们将该实现命名为 `AccountFactoryServant`。其实现形式如下: ```java class AccountFactoryServant extends _AccountFactoryImplBase { public Account createAccount(int acctNum, String acctName) { return (new AccountServant( acctNum, acctName)); } } ``` 然而,这似乎只是将对象创建问题转移到了工厂接口上。连接的客户端无法创建工厂对象,那么它们如何访问这些对象中的创建方法呢?简单的答案是,服务器将为每个工厂接口创建一个工厂对象,并将该对象注册到 ORB 上。客户端随后可以获取该工厂对象的引用,并使用该对象的创建方法来创建 CORBA 应用程序对象。 假设客户端已经获得了服务器创建的 `AccountFactory` 对象的引用,并且该引用存储在变量 `acctFactoryRef` 中,那么客户端可以使用以下代码创建一个账号为 12345、账户名称为“John Andrews”的 `Account` 对象: ```java Account acct = acctFactoryRef.createAccount( 12345,"John Andrews"); ``` 对于非持久对象,还应该定义销毁 CORBA 对象的方法(不过这里暂不涉及)。 #### 2. 示例:使用 Java IDL 实现对库存物品的平台无关访问 为了说明工厂接口及其关联的工厂对象的使用,下面通过一个具体示例进行详细介绍。 ##### 2.1 创建 IDL 文件 创建一个名为 `StockItem.idl` 的文件,其中包含一个名为 `Sales` 的模块。该模块包含 `StockItem` 和 `StockItemFactory` 两个接口。`StockItem` 接口包含与单个库存物品相关的属性和操作,为了简化,属性包括库存代码和当前库存水平,操作包括增加和减少该库存物品的库存水平。由于库存代码不应更改,因此将其声明为只读属性。`StockItemFactory` 接口包含 `createStockItem` 方法,用于创建具有指定库存代码和库存水平的 `StockItem` 对象。`StockItem.idl` 的内容如下: ```java module Sales { interface StockItem { readonly attribute string code; attribute long currentLevel; long addStock(in long incNumber); long removeStock(in long decNumber); }; interface StockItemFactory { StockItem createStockItem(in string newCode, in long newLevel); }; }; ``` ##### 2.2 编译 IDL 文件 由于客户端和服务器将在同一台机器上运行,因此使用 `-fall` 标志。执行 `idlj` 编译器的命令如下: ```bash idlj –fall StockItem.idl ``` 这将创建一个与模块名称相同的子目录(即 `Sales`),其中包含以下十二个文件(每个接口六个文件): - `StockItem.java` - `StockItemHelper.java` - `StockItemHolder.java` - `StockItemOperations.java` - `_StockItemImplBase.java` - `_StockItemStub.java` - `StockItemFactory.java` - `StockItemFactoryHelper.java` - `StockItemFactoryHolder.java` - `StockItemFactoryOperations.java` - `_ StockItemFactoryImplBase.java` - `_ StockItemFactoryStub.java` ##### 2.3 实现接口 遵循在接口名称后面添加“servant”的约定,创建 `StockItemServant` 和 `StockItemFactoryServant` 类,它们分别继承 `_StockItemImplBase` 和 `_StockItemFactoryImplBase` 类。代码如下: ```java class StockItemServant extends _StockItemImplBase { private String code = ""; private int currentLevel = 0; public StockItemServant(String newCode, int newLevel) { code = newCode; currentLevel = newLevel; } public int addStock(int incNumber) { currentLevel += incNumber; return currentLevel; } public int removeStock(int decNumber) { currentLevel -= decNumber; return currentLevel; } public String code() { return code; } public int currentLevel() { return currentLevel; } public void currentLevel(int newLevel) { currentLevel = newLevel; } } class StockItemFactoryServant extends _StockItemFactoryImplBase { public StockItem createStockItem(String newCode, int newLevel) { return (new StockItemServant(newCode,newLevel)); } } ``` 这些类将与服务器代码放在同一个文件中。 ##### 2.4 创建服务器 服务器程序名为 `StockItemServer.java`,它将包含上一步创建的服务类。该程序将导入 `Sales` 包以及以下三个标准 CORBA 包: - `org.omg.CosNaming;` - `org.omg.CosNaming.NamingContextPackage;` - `org.omg.CORBA.` ```java import Sales.*; import org.omg.CosNaming.*; import org.omg.CosNaming.NamingContextPackage.*; import org.omg.CORBA.*; public class StockItemServer { public static void main(String[] args) { try { ORB orb = ORB.init(args,null); StockItemServant stockServant = new StockItemServant("S0001", 100); orb.connect(stockServant); StockItemFactoryServant factoryServant = new StockItemFactoryServant(); orb.connect(factoryServant); org.omg.CORBA.Object objectRef = orb.resolve_initial_references("NameService"); NamingContext namingContext = NamingContextHelper.narrow(objectRef); NameComponent nameComp = new NameComponent("Stock", ""); NameComponent[] stockPath = {nameComp}; namingContext.rebind(stockPath,stockServant); NameComponent factoryNameComp = new NameComponent("StockFactory", ""); NameComponent[] factoryPath = {factoryNameComp}; namingContext.rebind( factoryPath,factoryServant); System.out.print("\nServer running..."); java.lang.Object syncObj = new java.lang.Object(); synchronized(syncObj) { syncObj.wait(); } } catch (Exception ex) { System.out.println("*** Server error! ***"); ex.printStackTrace(); } } } class StockItemServant extends _StockItemImplBase { //Code as shown in step 3 above. } class StockItemFactoryServant extends _StockItemFactoryImplBase { //Code as shown in step 3 above. } ``` ##### 2.5 编译服务器和 IDL 生成的文件 在 `Sales` 目录的上一级目录中,在命令窗口中执行以下命令: ```bash javac StockItemServer.java Sales\*.java ``` 如有错误,需进行修正并重新编译。 ##### 2.6 创建客户端 客户端程序名为 `StockItemClient.java`,它将导入 `Sales` 包以及 `org.omg.CosNaming` 和 `org.omg.CORBA` 包。除了执行上一个示例中客户端的步骤外,还将执行以下操作: - 对已存在的 `StockItem` 对象进行多次方法调用,而不仅仅是对 `Hello` 对象进行一次调用。 - 获取服务器创建并注册的 `StockItemFactory` 对象的引用。 - 使用上述引用调用 `createStockItem` 方法创建一个新的 `StockItem` 对象。 - 调用新 `StockIte
corwn 最低0.47元/天 解锁专栏
赠100次下载
继续阅读 点击查看下一篇
profit 400次 会员资源下载次数
profit 300万+ 优质博客文章
profit 1000万+ 优质下载资源
profit 1000万+ 优质文库回答
复制全文

相关推荐

李_涛

知名公司架构师
拥有多年在大型科技公司的工作经验,曾在多个大厂担任技术主管和架构师一职。擅长设计和开发高效稳定的后端系统,熟练掌握多种后端开发语言和框架,包括Java、Python、Spring、Django等。精通关系型数据库和NoSQL数据库的设计和优化,能够有效地处理海量数据和复杂查询。
最低0.47元/天 解锁专栏
赠100次下载
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
千万级 优质文库回答免费看
立即解锁

专栏目录

最新推荐

机械臂三维模型的材料选择与应用:材质决定命运,选对材料赢未来

![机械臂三维模型的材料选择与应用:材质决定命运,选对材料赢未来](https://blogs.sw.siemens.com/wp-content/uploads/sites/2/2023/12/Inverse-Kinematics-1024x466.png) # 摘要 机械臂作为先进制造和自动化系统的重要组成部分,其三维模型设计和材料选择对提高机械臂性能与降低成本至关重要。本文从基础理论出发,探讨了机械臂三维模型设计的基本原则,以及材料选择对于机械臂功能和耐久性的关键作用。通过对聚合物、金属和复合材料在实际机械臂应用案例的分析,本文阐述了不同材料的特性和应用实例。同时,提出了针对机械臂材料

ApacheThrift在脚本语言中的应用

### Apache Thrift在脚本语言中的应用 #### 1. Apache Thrift与PHP 在使用Apache Thrift和PHP时,首先要构建I/O栈。以下是构建I/O栈并调用服务的基本步骤: 1. 将传输缓冲区包装在二进制协议中,然后传递给服务客户端的构造函数。 2. 构建好I/O栈后,打开套接字连接,调用服务,最后关闭连接。 示例代码中的异常捕获块仅捕获Apache Thrift异常,并将其显示在Web服务器的错误日志中。 PHP错误通常在Web服务器的上下文中在服务器端表现出来。调试PHP程序的基本方法是检查Web服务器的错误日志。在Ubuntu 16.04系统中

并发编程:多语言实践与策略选择

### 并发编程:多语言实践与策略选择 #### 1. 文件大小计算的并发实现 在并发计算文件大小的场景中,我们可以采用数据流式方法。具体操作如下: - 创建两个 `DataFlowQueue` 实例,一个用于记录活跃的文件访问,另一个用于接收文件和子目录的大小。 - 创建一个 `DefaultPGroup` 来在线程池中运行任务。 ```plaintext graph LR A[创建 DataFlowQueue 实例] --> B[创建 DefaultPGroup] B --> C[执行 findSize 方法] C --> D[执行 findTotalFileS

Clojure多方法:定义、应用与使用场景

### Clojure 多方法:定义、应用与使用场景 #### 1. 定义多方法 在 Clojure 中,定义多方法可以使用 `defmulti` 函数,其基本语法如下: ```clojure (defmulti name dispatch-fn) ``` 其中,`name` 是新多方法的名称,Clojure 会将 `dispatch-fn` 应用于方法参数,以选择多方法的特定实现。 以 `my-print` 为例,它接受一个参数,即要打印的内容,我们希望根据该参数的类型选择特定的实现。因此,`dispatch-fn` 需要是一个接受一个参数并返回该参数类型的函数。Clojure 内置的

AWSLambda冷启动问题全解析

### AWS Lambda 冷启动问题全解析 #### 1. 冷启动概述 在 AWS Lambda 中,冷启动是指函数实例首次创建时所经历的一系列初始化步骤。一旦函数实例创建完成,在其生命周期内不会再次经历冷启动。如果在代码中添加构造函数或静态初始化器,它们仅会在函数冷启动时被调用。可以在处理程序类的构造函数中添加显式日志,以便在函数日志中查看冷启动的发生情况。此外,还可以使用 X-Ray 和一些第三方 Lambda 监控工具来识别冷启动。 #### 2. 冷启动的影响 冷启动通常会导致事件处理出现延迟峰值,这也是人们关注冷启动的主要原因。一般情况下,小型 Lambda 函数的端到端延迟

在线票务系统解析:功能、流程与架构

### 在线票务系统解析:功能、流程与架构 在当今数字化时代,在线票务系统为观众提供了便捷的购票途径。本文将详细解析一个在线票务系统的各项特性,包括系统假设、范围限制、交付计划、用户界面等方面的内容。 #### 系统假设与范围限制 - **系统假设** - **Cookie 接受情况**:互联网用户不强制接受 Cookie,但预计大多数用户会接受。 - **座位类型与价格**:每场演出的座位分为一种或多种类型,如高级预留座。座位类型划分与演出相关,而非个别场次。同一演出同一类型的座位价格相同,但不同场次的价格结构可能不同,例如日场可能比晚场便宜以吸引家庭观众。 -

【Nokia 5G核心网运维自动化】:提升效率与降低错误率的6大策略

![5g核心网和关键技术和功能介绍-nokia.rar](https://www.viavisolutions.com/sites/default/files/images/diagram-sba.png) # 摘要 随着5G技术的快速发展,其核心网运维面临一系列新的挑战。本文首先概述了5G核心网运维自动化的必要性,然后详细分析了Nokia 5G核心网架构及其运维挑战,包括组件功能、架构演变以及传统运维的局限性。接着,文章探讨了自动化策略的基础理论与技术,包括自动化工具的选择和策略驱动的自动化设计。重点介绍了Nokia 5G核心网运维自动化策略实践,涵盖网络部署、故障诊断与性能优化的自动化实

【电路测试与调试】:确保产品性能达标的专家级方法

![【电路测试与调试】:确保产品性能达标的专家级方法](https://ndtblog-us.fujifilm.com/wp-content/uploads/2022/05/01-what-is-electromagnetic-testing-min.png) # 摘要 本文全面综述了电路测试与调试的理论和实践,强调了测试与调试在电路设计和产品质量保证中的关键作用。从基本概念到自动化与智能技术的融合,本文详细介绍了电路测试的分类、参数指标、测试设备的选择使用,以及调试过程中的故障分析、技术和工具。通过国际和国内标准的讨论,强调了遵循标准流程的重要性,并通过案例研究,探讨了自动化测试与智能调试

响应式Spring开发:从错误处理到路由配置

### 响应式Spring开发:从错误处理到路由配置 #### 1. Reactor错误处理方法 在响应式编程中,错误处理是至关重要的。Project Reactor为其响应式类型(Mono<T> 和 Flux<T>)提供了六种错误处理方法,下面为你详细介绍: | 方法 | 描述 | 版本 | | --- | --- | --- | | onErrorReturn(..) | 声明一个默认值,当处理器中抛出异常时发出该值,不影响数据流,异常元素用默认值代替,后续元素正常处理。 | 1. 接收要返回的值作为参数<br>2. 接收要返回的值和应返回默认值的异常类型作为参数<br>3. 接收要返回

【系统文件缺失诊断手册】:WLANAPI.dll和WZCSAPI.dll修复秘籍

![【系统文件缺失诊断手册】:WLANAPI.dll和WZCSAPI.dll修复秘籍](https://img-blog.csdnimg.cn/direct/ddd2bd449f524d4db9b40baae4c409b6.png) # 摘要 系统文件的完整性和功能对于操作系统的稳定运行至关重要。本文首先分析了系统文件缺失的现象,进而详细探讨了WLANAPI.dll与WZCSAPI.dll这两个特定文件的功能及其在系统中的重要性。文中介绍了这些文件的基本作用、系统缺失它们时的表现以及如何正确安装和注册。接着,本文给出了系统文件缺失的预防措施、诊断方法和修复流程,旨在为用户提供一套完整的解决方