public class ArrayType<T> extends OpenType<T>
ArrayType
クラスは、公開データ値のn次元配列であるすべての公開データ値を記述するインスタンスを持つ公開型クラスです。
次に、有効なArrayType
インスタンスの例を示します。
// 2-dimension array of java.lang.String
ArrayType<String[][]> a1 = new ArrayType<String[][]>(2, SimpleType.STRING);
// 1-dimension array of int
ArrayType<int[]> a2 = new ArrayType<int[]>(SimpleType.INTEGER, true);
// 1-dimension array of java.lang.Integer
ArrayType<Integer[]> a3 = new ArrayType<Integer[]>(SimpleType.INTEGER, false);
// 4-dimension array of int
ArrayType<int[][][][]> a4 = new ArrayType<int[][][][]>(3, a2);
// 4-dimension array of java.lang.Integer
ArrayType<Integer[][][][]> a5 = new ArrayType<Integer[][][][]>(3, a3);
// 1-dimension array of java.lang.String
ArrayType<String[]> a6 = new ArrayType<String[]>(SimpleType.STRING, false);
// 1-dimension array of long
ArrayType<long[]> a7 = new ArrayType<long[]>(SimpleType.LONG, true);
// 1-dimension array of java.lang.Integer
ArrayType<Integer[]> a8 = ArrayType.getArrayType(SimpleType.INTEGER);
// 2-dimension array of java.lang.Integer
ArrayType<Integer[][]> a9 = ArrayType.getArrayType(a8);
// 2-dimension array of int
ArrayType<int[][]> a10 = ArrayType.getPrimitiveArrayType(int[][].class);
// 3-dimension array of int
ArrayType<int[][][]> a11 = ArrayType.getArrayType(a10);
// 1-dimension array of float
ArrayType<float[]> a12 = ArrayType.getPrimitiveArrayType(float[].class);
// 2-dimension array of float
ArrayType<float[][]> a13 = ArrayType.getArrayType(a12);
// 1-dimension array of javax.management.ObjectName
ArrayType<ObjectName[]> a14 = ArrayType.getArrayType(SimpleType.OBJECTNAME);
// 2-dimension array of javax.management.ObjectName
ArrayType<ObjectName[][]> a15 = ArrayType.getArrayType(a14);
// 3-dimension array of java.lang.String
ArrayType<String[][][]> a16 = new ArrayType<String[][][]>(3, SimpleType.STRING);
// 1-dimension array of java.lang.String
ArrayType<String[]> a17 = new ArrayType<String[]>(1, SimpleType.STRING);
// 2-dimension array of java.lang.String
ArrayType<String[][]> a18 = new ArrayType<String[][]>(1, a17);
// 3-dimension array of java.lang.String
ArrayType<String[][][]> a19 = new ArrayType<String[][][]>(1, a18);
ALLOWED_CLASSNAMES, ALLOWED_CLASSNAMES_LIST
コンストラクタと説明 |
---|
ArrayType(int dimension, OpenType<?> elementType)
dimension次元の要素(公開型がelementTypeの要素)の配列である公開データを記述するArrayTypeインスタンスを構築します。
|
ArrayType(SimpleType<?> elementType, boolean primitiveArray)
指定された
SimpleType の1次元ArrayType インスタンスを構築します。 |
修飾子と型 | メソッドと説明 |
---|---|
boolean |
equals(Object obj)
指定された
obj パラメータとこのArrayType インスタンスが等しいかどうかを比較します。 |
static <E> ArrayType<E[]> |
getArrayType(OpenType<E> elementType)
ArrayType のインスタンスを、型保証された方法で作成します。 |
int |
getDimension()
このArrayTypeインスタンスによって記述される配列の次元を返します。
|
OpenType<?> |
getElementOpenType()
このArrayTypeインスタンスによって記述された配列内に含まれる要素値の公開型を返します。
|
static <T> ArrayType<T> |
getPrimitiveArrayType(Class<T> arrayClass)
ArrayType のインスタンスを、型保証された方法で作成します。 |
int |
hashCode()
この
ArrayType インスタンスのハッシュ・コード値を返します。 |
boolean |
isPrimitiveArray()
この公開型が記述する公開データ値がプリミティブ配列の場合は
true を返し、そうでない場合はfalse を返します。 |
boolean |
isValue(Object obj)
objが、この
ArrayType インスタンスの値であるかどうかをテストします。 |
String |
toString()
この
ArrayType インスタンスの文字列表現を返します。 |
getClassName, getDescription, getTypeName, isArray
public ArrayType(int dimension, OpenType<?> elementType) throws OpenDataException
ArrayTypeインスタンス上でgetClassName
メソッドを呼び出すと、getElementOpenType().getClassName()の呼出しによって返される配列要素のクラス名ではなく、java.lang.Class
のgetName
メソッドに従って、記述する配列インスタンスのクラス名が返されます。
このArrayType
インスタンスの型名に対応する内部フィールドも、記述する配列インスタンスのクラス名に設定されます。つまり、getClassName
メソッドとgetTypeName
メソッドは同じ文字列値を返します。このArrayType
インスタンスの記述に対応する内部フィールドは、次のテンプレートに従う文字列値に設定されます。
例として、次のコードの抜粋を参照してください。
ArrayType<String[][][]> t = new ArrayType<String[][][]>(3, SimpleType.STRING);
System.out.println("array class name = " + t.getClassName());
System.out.println("element class name = " + t.getElementOpenType().getClassName());
System.out.println("array type name = " + t.getTypeName());
System.out.println("array type description = " + t.getDescription());
次の内容が出力されます。
array class name = [[[Ljava.lang.String;
element class name = java.lang.String
array type name = [[[Ljava.lang.String;
array type description = 3-dimension array of java.lang.String
また、次のコードも上記のコードと等価であり、出力は同じになります。
ArrayType<String[]> t1 = new ArrayType<String[]>(1, SimpleType.STRING);
ArrayType<String[][]> t2 = new ArrayType<String[][]>(1, t1);
ArrayType<String[][][]> t3 = new ArrayType<String[][][]>(1, t2);
System.out.println("array class name = " + t3.getClassName());
System.out.println("element class name = " + t3.getElementOpenType().getClassName());
System.out.println("array type name = " + t3.getTypeName());
System.out.println("array type description = " + t3.getDescription());
dimension
- このArrayTypeインスタンスによって記述される配列の次元。1以上。elementType
- このArrayTypeインスタンスによって記述される配列に含まれる要素値の公開型。SimpleType、CompositeType、TabularTypeのいずれかのインスタンス、またはSimpleType、CompositeType、TabularTypeのいずれかをelementTypeとして持つ別のArrayTypeのインスタンス。IllegalArgumentException
- dimension
が正の整数ではない場合。OpenDataException
- elementType's classNameが公開データに許可されたJavaクラス名でない場合。public ArrayType(SimpleType<?> elementType, boolean primitiveArray) throws OpenDataException
SimpleType
の1次元ArrayType
インスタンスを構築します。
このコンストラクタは、primitiveArray
がtrue
である場合に、プリミティブ型の配列の作成をサポートします。
プリミティブ配列では、getElementOpenType()
メソッドは、プリミティブ型の配列のラッパー型に対応するSimpleType
を返します。
ArrayTypeインスタンス上でgetClassName
メソッドを呼び出すと、getElementOpenType().getClassName()の呼出しによって返される配列要素のクラス名ではなく、java.lang.Class
のgetName
メソッドに従って、記述する配列インスタンスのクラス名が返されます。
このArrayType
インスタンスの型名に対応する内部フィールドも、記述する配列インスタンスのクラス名に設定されます。つまり、getClassName
メソッドとgetTypeName
メソッドは同じ文字列値を返します。このArrayType
インスタンスの記述に対応する内部フィールドは、次のテンプレートに従う文字列値に設定されます。
例として、次のコードの抜粋を参照してください。
ArrayType<int[]> t = new ArrayType<int[]>(SimpleType.INTEGER, true);
System.out.println("array class name = " + t.getClassName());
System.out.println("element class name = " + t.getElementOpenType().getClassName());
System.out.println("array type name = " + t.getTypeName());
System.out.println("array type description = " + t.getDescription());
次の内容が出力されます。
array class name = [I
element class name = java.lang.Integer
array type name = [I
array type description = 1-dimension array of int
elementType
- このArrayType
インスタンスによって記述される配列内に含まれる要素値のSimpleType
。primitiveArray
- この配列がプリミティブ配列を記述する場合はtrue
。IllegalArgumentException
- dimension
が正の整数ではない場合。OpenDataException
- primitiveArray
がtrue
で、elementType
がプリミティブ型の有効なSimpleType
ではない場合。public int getDimension()
public OpenType<?> getElementOpenType()
public boolean isPrimitiveArray()
true
を返し、そうでない場合はfalse
を返します。public boolean isValue(Object obj)
ArrayType
インスタンスの値であるかどうかをテストします。
このメソッドは、objがnullでない場合に限りtrue
を返します。objは、次のいずれかがtrueの場合に配列になります。
ArrayType
インスタンスがSimpleType要素または対応するプリミティブ型の配列を記述する場合、objのクラス名はこのArrayType
インスタンスに定義されたclassNameフィールドと同じ(getClassName
メソッドによって返される、次元情報を含むクラス名)になります。ArrayType
インスタンスがTabularData
インタフェースまたはCompositeData
インタフェースを実装するクラスの配列を記述する場合、objは宣言された配列に割り当てることができます。objに含まれる各要素は、nullか、このArrayType
インスタンスによって指定された要素の公開型に対して有効な値になります。public boolean equals(Object obj)
obj
パラメータとこのArrayType
インスタンスが等しいかどうかを比較します。
2つのArrayType
インスタンスは、同じ次元、要素の公開型、およびプリミティブ配列フラグを持つ配列インスタンスを記述する場合に限り等しいと言えます。
equals
、クラス: OpenType<T>
obj
- このArrayType
インスタンスと等しいかどうかを比較するオブジェクト。objがnull
の場合、またはArrayType
クラスのインスタンスではない場合、このメソッドはfalse
を返す。ArrayType
インスタンスと等しい場合はtrue
。Object.hashCode()
、HashMap
public int hashCode()
ArrayType
インスタンスのハッシュ・コード値を返します。
ArrayType
インスタンスのハッシュ・コードは、equals
比較で使用されるすべての情報要素(次元、要素の公開型、およびプリミティブ配列フラグ)のハッシュ・コードの合計になります。プリミティブ値のハッシュ・コードは、対応するboxed型のオブジェクトのハッシュ・コードです(trueのハッシュ・コードはBoolean.TRUE.hashCode()など)。これにより、Object.hashCode()
メソッドの一般規約によって要求される、任意の2つのArrayType
インスタンスt1
とt2
で、 t1.equals(t2)
であれば t1.hashCode()==t2.hashCode()
となることが保証されます。
ArrayType
インスタンスは不変で、このインスタンスのハッシュ・コードは、hashCode
の最初の呼出し時に1回だけ計算されます。その後の呼出しには、同じ値が返されます。
hashCode
、クラス: OpenType<T>
ArrayType
インスタンスのハッシュ・コード値Object.equals(java.lang.Object)
, System.identityHashCode(java.lang.Object)
public String toString()
ArrayType
インスタンスの文字列表現を返します。
この文字列表現は、このクラスの名前(javax.management.openmbean.ArrayType
)、型名、次元、このインスタンスに定義された要素の公開型およびプリミティブ配列フラグで構成されます。
ArrayType
インスタンスは不変で、このインスタンスの文字列表現は、toString
の最初の呼出し時に1回だけ計算されます。その後の呼出しには、同じ値が返されます。
public static <E> ArrayType<E[]> getArrayType(OpenType<E> elementType) throws OpenDataException
ArrayType
のインスタンスを、型保証された方法で作成します。
多次元配列は、このメソッドを必要な回数呼び出すことで構築できます。
同じパラメータを指定してこのメソッドを2回呼び出した場合、同じオブジェクトが返されるか、2つの同等の(同一ではない)オブジェクトが返される可能性があります。
例として、次のコードの抜粋を参照してください。
ArrayType<String[]> t1 = ArrayType.getArrayType(SimpleType.STRING);
ArrayType<String[][]> t2 = ArrayType.getArrayType(t1);
ArrayType<String[][][]> t3 = ArrayType.getArrayType(t2);
System.out.println("array class name = " + t3.getClassName());
System.out.println("element class name = " + t3.getElementOpenType().getClassName());
System.out.println("array type name = " + t3.getTypeName());
System.out.println("array type description = " + t3.getDescription());
次の内容が出力されます。
array class name = [[[Ljava.lang.String;
element class name = java.lang.String
array type name = [[[Ljava.lang.String;
array type description = 3-dimension array of java.lang.String
elementType
- このArrayTypeインスタンスによって記述される配列に含まれる要素値の公開型。SimpleType、CompositeType、TabularTypeのいずれかのインスタンス、またはSimpleType、CompositeType、TabularTypeのいずれかをelementTypeとして持つ別のArrayTypeのインスタンス。OpenDataException
- elementType's classNameが公開データに許可されたJavaクラス名でない場合。public static <T> ArrayType<T> getPrimitiveArrayType(Class<T> arrayClass)
ArrayType
のインスタンスを、型保証された方法で作成します。
同じパラメータを指定してこのメソッドを2回呼び出した場合、同じオブジェクトが返されるか、2つの同等の(同一ではない)オブジェクトが返される可能性があります。
例として、次のコードの抜粋を参照してください。
ArrayType<int[][][]> t = ArrayType.getPrimitiveArrayType(int[][][].class);
System.out.println("array class name = " + t.getClassName());
System.out.println("element class name = " + t.getElementOpenType().getClassName());
System.out.println("array type name = " + t.getTypeName());
System.out.println("array type description = " + t.getDescription());
次の内容が出力されます。
array class name = [[[I
element class name = java.lang.Integer
array type name = [[[I
array type description = 3-dimension array of int
arrayClass
- int[].class
、boolean[][].class
などのプリミティブ配列クラス。返されるArrayType
のgetElementOpenType()
メソッドは、プリミティブ型の配列のラッパー型に対応するSimpleType
を返す。IllegalArgumentException
-arrayClassがプリミティブ配列ではない場合。 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.