TopBlend: 
Here is the 
first difference.
 There are 19 differences.
is old. 
 is new. 
 
javax.management
Class ImmutableDescriptor
java.lang.Object
  
javax.management.ImmutableDescriptor
- 
All Implemented Interfaces:
 
 - 
Serializable
, 
Cloneable
, 
Descriptor
 
- 
public class ImmutableDescriptor
- extends Object
- implements Descriptor
   
An immutable descriptor.
- 
Since:
 
- 
1.6
 
- 
See Also:
 - 
Serialized Form
 
 
 
| 
Method Summary
 | 
| 
 
Descriptor
 | 
clone
() 
          Returns a descriptor which is equal to this descriptor. | 
| 
 boolean  | 
equals
( 
Object
 
 
          Compares 
 
          Indicates whether some other object is "equal to" 
this 
 
descriptor to the given object. 
 
one. 
 | 
| 
 
String
[] | 
getFieldNames
() 
          Returns all the field names in the descriptor. | 
| 
 
String
[] | 
getFields
() 
          Returns all of the fields contained in this descriptor as a string array. | 
| 
 
Object
 | 
getFieldValue
(
String
 fieldName) 
          Returns the value for a specific field name, or null if no value is present for that name. | 
| 
 
Object
[] | 
getFieldValues
(
String
... fieldNames) 
          Returns all the field values in the descriptor as an array of Objects. | 
| 
 int  | 
hashCode
()  
          Returns 
 
the 
 
a 
hash code value for 
 
this descriptor. 
 
the object. 
 | 
| 
 boolean | 
isValid
() 
          Returns true if all of the fields have legal values given their names. | 
| 
 void | 
removeField
(
String
 fieldName) 
          Removes a field from the descriptor. | 
| 
 void | 
setField
(
String
 fieldName,         
Object
 fieldValue) 
          This operation is unsupported since this class is immutable. | 
| 
 void | 
setFields
(
String
[] fieldNames,          
Object
[] fieldValues) 
          This operation is unsupported since this class is immutable. | 
| 
 
String
 | 
toString
() 
          Returns a string representation of the object. | 
| 
static 
ImmutableDescriptor
 | 
union
(
Descriptor
... descriptors) 
          Return an ImmutableDescriptor whose contents are the union of the given descriptors. | 
 
 
EMPTY_DESCRIPTOR
public static final ImmutableDescriptor EMPTY_DESCRIPTOR
- 
An empty descriptor.
 
ImmutableDescriptor
public ImmutableDescriptor(String[] fieldNames,
                           Object[] fieldValues)
- 
Construct a descriptor containing the given fields and values.
- 
Throws:
 - 
IllegalArgumentException
 - if either array is null, or if the arrays have different sizes, or if a field name is null or empty, or if the same field name appears more than once.
 
 
ImmutableDescriptor
public ImmutableDescriptor(String... fields)
- 
Construct a descriptor containing the given fields.  Each String must be of the form fieldName=fieldValue.  The field name ends at the first = character; for example if the String is a=b=c then the field name is a and its value is b=c.
- 
Throws:
 - 
IllegalArgumentException
 - if the parameter is null, or if a field name is empty, or if the same field name appears more than once, or if one of the strings does not contain an = character.
 
 
ImmutableDescriptor
public ImmutableDescriptor(Map<String,?> fields)
- 
Construct a descriptor where the names and values of the fields are the keys and values of the given Map.
- 
Throws:
 - 
IllegalArgumentException
 - if the parameter is null, or if a field name is null or empty, or if the same field name appears more than once (which can happen because field names are not case sensitive).
 
 
union
public static ImmutableDescriptor union(Descriptor... descriptors)
- 
Return an ImmutableDescriptor whose contents are the union of the given descriptors.  Every field name that appears in any of the descriptors will appear in the result with the value that it has when the method is called.  Subsequent changes to any of the descriptors do not affect the ImmutableDescriptor returned here.
In the simplest case, there is only one descriptor and the returned ImmutableDescriptor is a copy of its fields at the time this method is called:
 Descriptor d = something();
 ImmutableDescriptor copy = ImmutableDescriptor.union(d);
 
- 
 
- 
- 
Parameters:
 - 
descriptors - the descriptors to be combined.  Any of the descriptors can be null, in which case it is skipped.
 - 
Returns:
 - 
an ImmutableDescriptor that is the union of the given descriptors.  The returned object may be identical to one of the input descriptors if it is an ImmutableDescriptor that contains all of the required fields.
 - 
Throws:
 - 
IllegalArgumentException
 - if two Descriptors contain the same field name with different associated values.  Primitive array values are considered the same if they are of the same type with the same elements.  Object array values are considered the same if 
Arrays.deepEquals(Object[],Object[])
 returns true.
 
 
 
getFieldValue
public final Object getFieldValue(String fieldName)
- 
Description copied from interface: 
Descriptor
 
- 
Returns the value for a specific field name, or null if no value is present for that name.
- 
- 
Specified by:
 - 
getFieldValue
 in interface 
Descriptor
 
 
- 
- 
Parameters:
 - 
fieldName - the field name.
 - 
Returns:
 - 
the corresponding value, or null if the field is not present.
 
 
 
getFields
public final String[] getFields()
- 
Description copied from interface: 
Descriptor
 
- 
Returns all of the fields contained in this descriptor as a string array.
- 
- 
Specified by:
 - 
getFields
 in interface 
Descriptor
 
 
- 
- 
Returns:
 - 
String array of fields in the format 
fieldName=fieldValue
If the value of a field is not a String, then the toString() method will be called on it and the returned value, enclosed in parentheses, used as the value for the field in the returned array. If the value of a field is null, then the value of the field in the returned array will be empty.  If the descriptor is empty, you will get an empty array. - 
See Also:
 - 
Descriptor.setFields(java.lang.String[], java.lang.Object[])
 
 
 
getFieldValues
public final Object[] getFieldValues(String... fieldNames)
- 
Description copied from interface: 
Descriptor
 
- 
Returns all the field values in the descriptor as an array of Objects. The returned values are in the same order as the fieldNames String array parameter.
- 
- 
Specified by:
 - 
getFieldValues
 in interface 
Descriptor
 
 
- 
- 
Parameters:
 - 
fieldNames - String array of the names of the fields that the values should be returned for.  If the array is empty then an empty array will be returned.  If the array is null then all values will be returned, as if the parameter were the array returned by 
Descriptor.getFieldNames()
.  If a field name in the array does not exist, including the case where it is null or the empty string, then null is returned for the matching array element being returned.
 - 
Returns:
 - 
Object array of field values. If the list of fieldNames is empty, you will get an empty array.
 
 
 
getFieldNames
public final String[] getFieldNames()
- 
Description copied from interface: 
Descriptor
 
- 
Returns all the field names in the descriptor.
- 
- 
Specified by:
 - 
getFieldNames
 in interface 
Descriptor
 
 
- 
- 
Returns:
 - 
String array of field names. If the descriptor is empty, you will get an empty array.
 
 
 
equals
public boolean equals(Object o)
- 
Compares this descriptor to the given object. The objects are equal if the given object is also a Descriptor, and if the two Descriptors have the same field names (possibly differing in case) and the same associated values. The respective values for a field in the two Descriptors are equal if the following conditions hold: 
Description copied from class: 
Object
 
- 
Indicates whether some other object is "equal to" this one. 
The equals method implements an equivalence relation on non-null object references: 
- 
If one value is null then the other must be too. 
 
- 
If one value is a primitive array then the other must be a primitive array of the same type with the same elements. 
 
- 
If one value is an object array then the other must be too and 
Arrays.deepEquals(Object[],Object[])
 
- 
Otherwise 
Object.equals(Object)
 
- 
It is 
reflexive 
: for any non-null reference value x, x.equals(x) should return true. 
 - 
It is 
symmetric 
: for any non-null reference values x and y, x.equals(y) should return true if and only if y.equals(x) returns true. 
 - 
It is 
transitive 
: for any non-null reference values x, y, and z, if x.equals(y) returns true and y.equals(z) returns true, then x.equals(z) should return true. 
 - 
It is 
consistent 
: for any non-null reference values x and y, multiple invocations of 
x.equals(y) 
consistently return true or consistently return false, provided no information used in equals comparisons on the objects is modified. 
 - 
For any non-null reference value x, x.equals(null) should return false. 
 
The 
equals 
method for class Object implements the most discriminating possible equivalence relation on objects; that is, for any non-null reference values x and y, this method returns true if and only if x and y refer to the same object (x == y has the value true). 
Note that it is generally necessary to override the 
hashCode 
method whenever this method is overridden, so as to maintain the general contract for the 
hashCode 
method, which states that equal objects must have equal hash codes. 
- 
- 
Specified by:
 - 
equals
 in interface 
Descriptor
 - 
Overrides:
 - 
equals
 in class 
Object
 
 
- 
- 
Parameters:
 - 
o - the 
reference 
object 
with which 
to 
compare with. 
compare. 
 - 
Returns:
 - 
true if 
this object is 
the 
objects are 
same as 
the 
same; 
obj argument; 
false otherwise.  - 
See Also:
 - 
Object.hashCode()
, 
Hashtable
 
 
 
hashCode
public int hashCode()
- 
Description copied from class: 
Object
 
- 
Returns a hash code value for the object. This method is supported for the benefit of hashtables such as those provided by java.util.Hashtable. 
Returns the hash code value for this descriptor. The hash code is computed as the sum of the hash codes for each field in the descriptor. The hash code of a field with name n and value v is n.toLowerCase().hashCode() ^ h. Here h is the hash code of v, computed as follows: 
The general contract of hashCode is: 
- 
If v is null then h is 0. 
 
- 
If v is a primitive array then h is computed using the appropriate overloading of java.util.Arrays.hashCode. 
 
- 
If v is an object array then h is computed using 
Arrays.deepHashCode(Object[])
 
- 
Otherwise h is v.hashCode(). 
 
- 
Whenever it is invoked on the same object more than once during an execution of a Java application, the 
hashCode 
method must consistently return the same integer, provided no information used in 
equals 
comparisons on the object is modified. This integer need not remain consistent from one execution of an application to another execution of the same application. 
 - 
If two objects are equal according to the 
equals(Object) 
method, then calling the hashCode method on each of the two objects must produce the same integer result. 
 - 
It is not required that if two objects are unequal according to the 
Object.equals(java.lang.Object)
hashCode 
method on each of the two objects must produce distinct integer results. However, the programmer should be aware that producing distinct integer results for unequal objects may improve the performance of hashtables. 
 
As much as is reasonably practical, the hashCode method defined by class 
Object 
does return distinct integers for distinct objects. (This is typically implemented by converting the internal address of the object into an integer, but this implementation technique is not required by the Java 
TM 
programming language.) 
- 
- 
Specified by:
 - 
hashCode
 in interface 
Descriptor
 - 
Overrides:
 - 
hashCode
 in class 
Object
 
 
- 
- 
Returns:
 - 
A 
a 
hash code value for this object.  - 
See Also:
 - 
Object.equals(java.lang.Object)
, 
Hashtable
 
 
 
toString
public String toString()
- 
Description copied from class: 
Object
 
- 
Returns a string representation of the object. In general, the  toString method returns a string that  "textually represents" this object. The result should  be a concise but informative representation that is easy for a  person to read. It is recommended that all subclasses override this method. 
 The toString method for class Object  returns a string consisting of the name of the class of which the  object is an instance, the at-sign character `@', and  the unsigned hexadecimal representation of the hash code of the  object. In other words, this method returns a string equal to the  value of: 
 getClass().getName() + '@' + Integer.toHexString(hashCode())
 
- 
- 
Overrides:
 - 
toString
 in class 
Object
 
 
- 
- 
Returns:
 - 
a string representation of the object.
 
 
 
isValid
public boolean isValid()
- 
Returns true if all of the fields have legal values given their names.  This method always returns true, but a subclass can override it to return false when appropriate.
- 
- 
Specified by:
 - 
isValid
 in interface 
Descriptor
 
 
- 
- 
Returns:
 - 
true if the values are legal.
 - 
Throws:
 - 
RuntimeOperationsException
 - if the validity checking fails. The method returns false if the descriptor is not valid, but throws this exception if the attempt to determine validity fails.
 
 
 
clone
public Descriptor clone()
- 
Returns a descriptor which is equal to this descriptor. Changes to the returned descriptor will have no effect on this descriptor, and vice versa.
This method returns the object on which it is called. A subclass can override it to return another object provided the contract is respected.
- 
- 
Specified by:
 - 
clone
 in interface 
Descriptor
 - 
Overrides:
 - 
clone
 in class 
Object
 
 
- 
- 
Returns:
 - 
a clone of this instance.
 - 
Throws:
 - 
RuntimeOperationsException
 - for illegal value for field Names or field Values. If the descriptor construction fails for any reason, this exception will be thrown.
 - 
See Also:
 - 
Cloneable
 
 
 
setFields
public final void setFields(String[] fieldNames,
                            Object
[] fieldValues)
 throws 
RuntimeOperationsException
[] fieldValues) 
- 
This operation is unsupported since this class is immutable.  If this call would change a mutable descriptor with the same contents, then a 
RuntimeOperationsException
 wrapping an 
UnsupportedOperationException
 is thrown.  Otherwise, the behavior is the same as it would be for a mutable descriptor: either an exception is thrown because of illegal parameters, or there is no effect.
- 
- 
Specified by:
 - 
setFields
 in interface 
Descriptor
 
 
- 
- 
Parameters:
 - 
fieldNames - String array of field names. The array and array elements cannot be null.
- 
fieldValues - Object array of the corresponding field values. The array cannot be null. Elements of the array can be null.
  - 
Throws:
 - 
RuntimeOperationsException
- if the change fails for any reason. Wrapped exception is 
IllegalArgumentException
- for illegal value for field Names or field Values. Neither can be null. The array lengths must be equal. If the call would succeed on a mutable descriptor and change its contents, then this exception will be thrown and the wrapped exception will be 
UnsupportedOperationException
if fieldNames or fieldValues is null, or if the arrays are of different lengths, or if there is an illegal value in one of them. Wrapped exception is 
UnsupportedOperationException
if the descriptor is immutable, and the call would change its contents. 
. 
 - 
See Also:
 - 
Descriptor.getFields()
getFields()
 
 
 
setField
public final void setField(String fieldName,
                           Object
 fieldValue)
 throws 
RuntimeOperationsException
 fieldValue) 
- 
This operation is unsupported since this class is immutable.  If this call would change a mutable descriptor with the same contents, then a 
RuntimeOperationsException
 wrapping an 
UnsupportedOperationException
 is thrown.  Otherwise, the behavior is the same as it would be for a mutable descriptor: either an exception is thrown because of illegal parameters, or there is no effect.
- 
- 
Specified by:
 - 
setField
 in interface 
Descriptor
 
 
- 
- 
Parameters:
 - 
fieldName - The field name to be set. Cannot be null or empty.
- 
fieldValue - The field value to be set for the field name. Can be null if that is a valid value for the field.
  - 
Throws:
 - 
RuntimeOperationsException
 - if the field name or field value is illegal (wrapped exception is 
IllegalArgumentException
); or if the descriptor is immutable (wrapped exception is 
UnsupportedOperationException
). If the call would succeed on a mutable descriptor and change its contents, then this exception will be thrown and the wrapped exception will be 
UnsupportedOperationException
). 
. 
 
 
 
removeField
public final void removeField(String fieldName)
- 
Removes a field from the descriptor.
- 
- 
Specified by:
 - 
removeField
 in interface 
Descriptor
 
 
- 
- 
Parameters:
 - 
fieldName - String name of the field to be removed. If the field name is illegal or the field is not found, no exception is thrown.
 - 
Throws:
 - 
RuntimeOperationsException
 - if a field of the given name exists and the descriptor is immutable.  The wrapped exception will be an 
UnsupportedOperationException
.