Array (Java 2 Platform SE 5.0) (original) (raw)
java.lang.reflect
Class Array
java.lang.Object
java.lang.reflect.Array
public final class Array
extends Object
The Array
class provides static methods to dynamically create and access Java arrays.
Array
permits widening conversions to occur during a get or set operation, but throws an IllegalArgumentException
if a narrowing conversion would occur.
Method Summary | |
---|---|
static Object | [get](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object. |
static boolean | [getBoolean](../../../java/lang/reflect/Array.html#getBoolean%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a boolean. |
static byte | [getByte](../../../java/lang/reflect/Array.html#getByte%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a byte. |
static char | [getChar](../../../java/lang/reflect/Array.html#getChar%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a char. |
static double | [getDouble](../../../java/lang/reflect/Array.html#getDouble%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a double. |
static float | [getFloat](../../../java/lang/reflect/Array.html#getFloat%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a float. |
static int | [getInt](../../../java/lang/reflect/Array.html#getInt%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as an int. |
static int | getLength(Object array) Returns the length of the specified array object, as an int. |
static long | [getLong](../../../java/lang/reflect/Array.html#getLong%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a long. |
static short | [getShort](../../../java/lang/reflect/Array.html#getShort%28java.lang.Object, int%29)(Object array, int index) Returns the value of the indexed component in the specified array object, as a short. |
static Object | [newInstance](../../../java/lang/reflect/Array.html#newInstance%28java.lang.Class, int%29)(Class<?> componentType, int length) Creates a new array with the specified component type and length. |
static Object | [newInstance](../../../java/lang/reflect/Array.html#newInstance%28java.lang.Class, int[]%29)(Class<?> componentType, int[] dimensions) Creates a new array with the specified component type and dimensions. |
static void | [set](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)(Object array, int index,Object value) Sets the value of the indexed component of the specified array object to the specified new value. |
static void | [setBoolean](../../../java/lang/reflect/Array.html#setBoolean%28java.lang.Object, int, boolean%29)(Object array, int index, boolean z) Sets the value of the indexed component of the specified array object to the specified boolean value. |
static void | [setByte](../../../java/lang/reflect/Array.html#setByte%28java.lang.Object, int, byte%29)(Object array, int index, byte b) Sets the value of the indexed component of the specified array object to the specified byte value. |
static void | [setChar](../../../java/lang/reflect/Array.html#setChar%28java.lang.Object, int, char%29)(Object array, int index, char c) Sets the value of the indexed component of the specified array object to the specified char value. |
static void | [setDouble](../../../java/lang/reflect/Array.html#setDouble%28java.lang.Object, int, double%29)(Object array, int index, double d) Sets the value of the indexed component of the specified array object to the specified double value. |
static void | [setFloat](../../../java/lang/reflect/Array.html#setFloat%28java.lang.Object, int, float%29)(Object array, int index, float f) Sets the value of the indexed component of the specified array object to the specified float value. |
static void | [setInt](../../../java/lang/reflect/Array.html#setInt%28java.lang.Object, int, int%29)(Object array, int index, int i) Sets the value of the indexed component of the specified array object to the specified int value. |
static void | [setLong](../../../java/lang/reflect/Array.html#setLong%28java.lang.Object, int, long%29)(Object array, int index, long l) Sets the value of the indexed component of the specified array object to the specified long value. |
static void | [setShort](../../../java/lang/reflect/Array.html#setShort%28java.lang.Object, int, short%29)(Object array, int index, short s) Sets the value of the indexed component of the specified array object to the specified short value. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, [wait](../../../java/lang/Object.html#wait%28long, int%29) |
Method Detail |
---|
newInstance
public static Object newInstance(Class<?> componentType, int length) throws NegativeArraySizeException
Creates a new array with the specified component type and length. Invoking this method is equivalent to creating an array as follows:
int[] x = {length}; Array.newInstance(componentType, x);
Parameters:
componentType
- the Class
object representing the component type of the new array
length
- the length of the new array
Returns:
the new array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- if the specifiedcomponentType
parameter is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- if componentType is Void.TYPE
[NegativeArraySizeException](../../../java/lang/NegativeArraySizeException.html "class in java.lang")
- if the specified length
is negative
newInstance
public static Object newInstance(Class<?> componentType, int[] dimensions) throws IllegalArgumentException, NegativeArraySizeException
Creates a new array with the specified component type and dimensions. If componentType
represents a non-array class or interface, the new array has dimensions.length
dimensions and componentType
as its component type. IfcomponentType
represents an array class, the number of dimensions of the new array is equal to the sum of dimensions.length
and the number of dimensions of componentType
. In this case, the component type of the new array is the component type ofcomponentType
.
The number of dimensions of the new array must not exceed the number of array dimensions supported by the implementation (typically 255).
Parameters:
componentType
- the Class
object representing the component type of the new array
dimensions
- an array of int
types representing the dimensions of the new array
Returns:
the new array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- if the specified componentType
argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- if the specified dimensions
argument is a zero-dimensional array, or if the number of requested dimensions exceeds the limit on the number of array dimensions supported by the implementation (typically 255), or if componentType is Void.TYPE.
[NegativeArraySizeException](../../../java/lang/NegativeArraySizeException.html "class in java.lang")
- if any of the components in the specified dimensions
argument is negative.
getLength
public static int getLength(Object array) throws IllegalArgumentException
Returns the length of the specified array object, as an int
.
Parameters:
array
- the array
Returns:
the length of the array
Throws:
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- if the object argument is not an array
get
public static Object get(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object. The value is automatically wrapped in an object if it has a primitive type.
Parameters:
array
- the array
index
- the index
Returns:
the (possibly wrapped) value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
getBoolean
public static boolean getBoolean(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a boolean
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getByte
public static byte getByte(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a byte
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getChar
public static char getChar(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a char
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getShort
public static short getShort(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a short
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getInt
public static int getInt(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as an int
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getLong
public static long getLong(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a long
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getFloat
public static float getFloat(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a float
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
getDouble
public static double getDouble(Object array, int index) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Returns the value of the indexed component in the specified array object, as a double
.
Parameters:
array
- the array
index
- the index
Returns:
the value of the indexed component in the specified array
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object is not an array, or if the indexed element cannot be converted to the return type by an identity or widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[get(java.lang.Object, int)](../../../java/lang/reflect/Array.html#get%28java.lang.Object, int%29)
set
public static void set(Object array, int index, Object value) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified new value. The new value is first automatically unwrapped if the array has a primitive component type.
Parameters:
array
- the array
index
- the index into the array
value
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the array component type is primitive and an unwrapping conversion fails
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
setBoolean
public static void setBoolean(Object array, int index, boolean z) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified boolean
value.
Parameters:
array
- the array
index
- the index into the array
z
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setByte
public static void setByte(Object array, int index, byte b) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified byte
value.
Parameters:
array
- the array
index
- the index into the array
b
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setChar
public static void setChar(Object array, int index, char c) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified char
value.
Parameters:
array
- the array
index
- the index into the array
c
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setShort
public static void setShort(Object array, int index, short s) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified short
value.
Parameters:
array
- the array
index
- the index into the array
s
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setInt
public static void setInt(Object array, int index, int i) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified int
value.
Parameters:
array
- the array
index
- the index into the array
i
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setLong
public static void setLong(Object array, int index, long l) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified long
value.
Parameters:
array
- the array
index
- the index into the array
l
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setFloat
public static void setFloat(Object array, int index, float f) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified float
value.
Parameters:
array
- the array
index
- the index into the array
f
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
setDouble
public static void setDouble(Object array, int index, double d) throws IllegalArgumentException, ArrayIndexOutOfBoundsException
Sets the value of the indexed component of the specified array object to the specified double
value.
Parameters:
array
- the array
index
- the index into the array
d
- the new value of the indexed component
Throws:
[NullPointerException](../../../java/lang/NullPointerException.html "class in java.lang")
- If the specified object argument is null
[IllegalArgumentException](../../../java/lang/IllegalArgumentException.html "class in java.lang")
- If the specified object argument is not an array, or if the specified value cannot be converted to the underlying array's component type by an identity or a primitive widening conversion
[ArrayIndexOutOfBoundsException](../../../java/lang/ArrayIndexOutOfBoundsException.html "class in java.lang")
- If the specified index
argument is negative, or if it is greater than or equal to the length of the specified array
See Also:
[set(java.lang.Object, int, java.lang.Object)](../../../java/lang/reflect/Array.html#set%28java.lang.Object, int, java.lang.Object%29)
Submit a bug or feature
For further API reference and developer documentation, see Java 2 SDK SE Developer Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
Copyright © 2004, 2010 Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.