Ice分布式编程:数据中心虚拟化技术详解

需积分: 49 25 下载量 93 浏览量 更新于2024-08-09 收藏 7.08MB PDF 举报
"对象体现-数据中心虚拟化技术权威指南 高清 电子书 下载pdf" 在《对象体现-数据中心虚拟化技术权威指南》中,主要讨论了如何在Ice(Internet Communications Engine)框架下实现对象体现,特别是对于数据中心的虚拟化技术。Ice是一种高效的分布式对象中间件,用于构建跨平台的、高性能的应用程序。以下将详细阐述对象体现的四个关键步骤以及智能指针在其中的作用。 首先,对象体现是将实际的服务实现(servant)与客户端交互的接口绑定的过程。在Ice中,servant是实现了特定接口的对象,它们处理客户端的调用请求。例如,`NodeI` 类是一个 servant 类,它继承自 `Node` 接口,并提供了具体的实现。 1. **实例化 Servant**:这是创建对象的初步步骤,例如 `NodePtr servant = new NodeI("Fred");` 这行代码会在堆上创建一个 `NodeI` 的实例,并将其存储在 `NodePtr` 智能指针中。`NodePtr` 是一个指向 `Node` 基类的智能指针,能够管理 `NodeI` 类的实例生命周期。 2. **创建对象标识**:每个Ice对象都有一个唯一的标识,这个标识用于区分不同的对象实例。在创建servant后,需要为该servant所代表的Ice对象生成这个标识。 3. **向Ice运行时注册Servant**:接下来,开发者需要将新创建的servant告知Ice运行时系统,以便它能够处理客户端的调用。这通常通过调用特定的运行时API完成。 4. **传递对象代理给客户端**:最后,将对象的代理(proxy)传递给客户端,代理是客户端用来与服务器对象通信的接口。客户端通过代理进行方法调用,而实际的服务执行则发生在服务器端的servant中。 在代码实现中,有时需要直接调用 `NodeI` 派生类的特有成员函数,这就需要用到特定于派生类的智能指针,如 `NodeIPtr`。`NodeIPtr` 是使用 `IceUtil::Handle` 模板定义的,它可以确保正确地调用 `NodeI` 类的成员函数,同时提供智能指针的内存管理功能,避免内存泄漏。 总结来说,对象体现是Ice中实现服务的关键步骤,包括实例化servant、创建对象标识、注册到运行时和传递代理。使用智能指针如 `NodeIPtr` 可以简化内存管理和类型安全,使得代码更加健壮。《对象体现-数据中心虚拟化技术权威指南》深入介绍了这些概念和技术,是理解并应用Ice分布式程序设计的重要参考资料。