Module  java.corba

Package org.omg.CosNaming

为Java IDL提供命名服务。 对象请求代理守护程序(ORBD)还包括暂时和持久命名服务。

软件包及其所有类和接口是通过在idlj上运行工具idlj生成的,该文件nameservice.idl OMG IDL编写的模块。

包装规格

有关Java [tm] Platform,Standard Edition 6,ORB符合的官方规范支持部分的精确列表,请参阅Official Specifications for CORBA support in Java[tm] SE 6

接口

org.omg.CosNaming包含两个公共接口和几个辅助类。

接口是:

  • NamingContext
  • BindingIterator

这两个接口提供绑定/取消绑定名称和对象引用,检索绑定对象引用以及遍历绑定列表的方法。 NamingContext接口提供命名服务的主要功能, BindingIterator提供了一种迭代名称/对象引用绑定列表的方法。

辅助课

为了将OMG IDL接口映射到Java编程语言,idlj编译器创建可以被认为是辅助类的Java类。 此处包含接口NamingContextBindingIterator使用的生成辅助类的注释。

NamingContextBindingIterator使用的BindingIterator

以下是命名服务使用的类。 (帮助者和持有者类,为这里列出的每个类生成,将在下面讨论。)
  • public final class NameComponent - 一个名称的构建块。 (名称绑定到命名上下文中的对象引用。)

    一个名称是一个或多个NameComponent对象的数组。 一个名字用一个NameComponent称为简单名称 ; 具有多个NameComponent对象的名称称为复合名称

    一个NameComponent对象由两个字段组成:

    1. id - 一个String用作标识符
    2. kind - 可用于任何描述目的的String 它的重要性在于它可以用来描述一个对象而不影响语法。 例如,C编程语言使用将扩展名“.c”附加到文件名的句法约定,以指示它是源代码文件。 NameComponent对象中, kind字段可用于描述对象的类型,而不是文件扩展名或其他一些句法约定。 所述的值的实例kind字段包括琴弦"c_source""object_code""executable""postscript" ,和"" kind字段是空字符串并不罕见。

    在名字中,除了last之外,每个NameComponent对象表示一个NamingContext对象; 最后一个NameComponent对象表示绑定的对象引用。 这与路径名称类似,其中最后一个名称是文件名,其前面的所有名称都是目录名称。

  • public final class Binding - 将名称与对象引用或命名上下文相关联的对象。 A Binding对象有两个字段:
    1. binding_name - 表示绑定名称的一个或多个NameComponent对象的数组
    2. binding_type - 一个BindingType对象,指示绑定是在名称和对象引用之间,还是名称和命名上下文之间

    接口NamingContext具有用于绑定/取消绑定名称与对象引用或命名上下文,列表绑定和解析绑定的方法(给定一个名称,方法resolve返回绑定对象引用)。

  • public final class BindingType - 一个对象,指定给定的Binding对象是否是名称和对象引用(即不是命名上下文)之间或名称和命名上下文之间的绑定。

    BindingType类由两个方法和四个常量组成。 其中两个常数是BindingType对象,两个是int

    BindingType对象可以传递给类的构造函数Binding或用作参数或返回值。 这些BindingType对象是:

    • public static final BindingType nobject - 表示绑定与对象引用
    • public static final BindingType ncontext - 表示绑定是使用命名上下文

    int常量可以提供给方法from_int来创建BindingType对象,或者它们可以返回值为方法value 这些常数是:

    • public static final int _nobject
    • public static final int _ncontext
    如果方法from_int提供_nobject_ncontext以外的任何东西,它将抛出异常org.omg.CORBA.BAD_PARAM

    用法如下:

      BindingType btObject = from_int(_nobject);
           BindingType btContext = from_int(_ncontext); 
    变量btObject是指一个BindingType对象,初始化为表示具有对象引用的绑定。 变量btContext是指BindingType对象初始化以表示与NamingContex对象的绑定。

    方法value返回_nobject_ncontext ,因此在以下代码行中,变量bt将包含_nobject_ncontext

      int bt = BindingType.value(); 

持有人类

OMG IDL使用OUT和INOUT参数从操作返回值。 没有OUT和INOUT参数的Java编程语言的映射为每个类型创建一个称为持有者类的特殊类。 持有者类的实例可以作为参数传递给Java方法,并且可以将值分配给其value字段。 这允许它执行OUT或INOUT参数的功能。

为包org.omg.CosNaming生成以下持有org.omg.CosNaming

  • NamingContextHolder
  • BindingIteratorHolder
  • BindingHolder
  • BindingListHolder
  • BindingTypeHolder
  • NameComponentHolder
  • NameHolder

需要注意的是,在org.omg.CORBA包,对于每一个基本的Java类型的holder类: IntHolderShortHolderStringHolder ,等等。

还需要注意的是有一个NameHolder即使没有课Name类; 同样,还有一个BindingListHolder即使没有课BindingList类。 这是真的,因为在OMG IDL界面中, NameBindingList都是typedef s。 没有从IDL typedef到Java构造的映射,但是如果typedef用于序列或阵列,则会生成保持类。 作为映射到Java编程语言, NameNameComponent对象的数组,而BindingListBinding对象的数组。 所有持有者类至少有两个构造函数和一个字段:

  • value字段 - 用作OUT或INOUT参数的类型实例。 例如, value一个的字段NamingContextHolder将是NamingContext对象。
  • 默认构造函数 - 一个构造函数,用于创建使用该类型的默认值初始化的新的持有者对象。 例如,使用默认构造函数创建的新的BindingHolder对象的value字段将设置为null因为它是对象的默认值。 其他默认设置是falseboolean0的数字和char类型,并null对象引用。
  • 一个实例的构造函数 - 一个构造函数,它创建一个新的持有者对象,其中的一个实例提供了value字段

用户定义类型(Java类)的持有者类具有三种方法,但应用程序开发人员不直接使用它们。

助手班

为OMG IDL接口中的所有用户定义类型生成的助手类提供了处理这些类型所需的静态方法。

应用程序员使用的辅助类中只有一种方法:方法narrow 只有从IDL接口映射的Java接口将具有一个帮助类,其中包含一个narrow方法,所以在CosNaming包中,只有NamingContextHelperBindingIteratorHelper都有一个narrow方法。

  • public static NamingContext narrow(org.omg.CORBA.Object obj) - 将给定的CORBA对象转换为NamingContext对象
  • public static BindingIterator narrow(org.omg.CORBA.Object obj) - 将给定的CORBA对象转换为BindingIterator对象

套装org.omg.CosNaming.NamingContextPackage

该包为包org.omg.CosNamingorg.omg.CosNaming类中使用的异常提供了助手和持有NotFoundReason ,这为NotFound提供了异常的NotFound

Helper和Holder课程有以下例外:

  • AlreadyBound
  • CannotProceed
  • InvalidName
  • NotEmpty
  • NotFound

命名服务兼容性

Sun的CosNaming包的实现符合OMG COSNaming规范。 换句话说,Sun的命名服务中的API是根据OMG提供的命名服务的指导来实现的。 因此,如果第三方供应商实施了符合OMG的命名服务,则可以在Sun的实施CosNaming和第三方供应商的实施之间切换。 然而,重要的是要明白,不同的供应商实现命名服务的方式可能会有很小的变化,例如异常字符串的差异。

使用第三方命名服务的说明

虽然我们鼓励使用来自一个供应商的ORB和ORB服务,但可以使用Sun的RMI-IIOP ORB插入第三方的COSNaming实现。 以下是以下步骤:
  1. 为Bootstrap服务器创建一个属性文件,并给它两个条目。 例如,您可以将此属性文件/tmp/services ,并将以下内容添加到其中: NameService, <Stringified IOR of the Root Naming Context>

    NameService与要使用的CosNaming实现的根命名上下文相关联。

  2. 使用以下命令启动独立Bootstrap服务器:
       java -classpath $(CLASSPATH) com.sun.corba.ee.internal.CosNaming.BootstrapServer -InitialServicesFile "/tmp/services" [-ORBInitialPort port]  

    请注意,命令结尾处的方括号表示指定端口号是可选的。

现在当应用程序调用方法org.omg.CORBA.ORB.resolve_initial_references ,CORBA进程将联系引导服务器以获取根命名上下文。

包装规格

相关文档

有关如何使用CosNaming API的概述和示例,请参阅:

有关Java IDL的概述,请参阅:

从以下版本开始:
JDK1.3