public class HashAttributeSet extends Object implements AttributeSet, Serializable
Class HashAttributeSet provides an AttributeSet
implementation with characteristics of a hash map.
public HashAttributeSet()
Construct a new, empty attribute set.
public HashAttributeSet(Attribute attribute)
Construct a new attribute set, initially populated with the given attribute.
attribute
- Attribute value to add to the set.NullPointerException
- (unchecked exception) Thrown if attribute
is null.public HashAttributeSet(Attribute[] attributes)
Construct a new attribute set, initially populated with the values from the given array. The new attribute set is populated by adding the elements of attributes
array to the set in sequence, starting at index 0. Thus, later array elements may replace earlier array elements if the array contains duplicate attribute values or attribute categories.
attributes
- Array of attribute values to add to the set. If null, an empty attribute set is constructed.NullPointerException
- (unchecked exception) Thrown if any element of attributes
is null.public HashAttributeSet(AttributeSet attributes)
Construct a new attribute set, initially populated with the values from the given set.
attributes
- Set of attributes from which to initialise this set. If null, an empty attribute set is constructed.protected HashAttributeSet(Class<?> interfaceName)
Construct a new, empty attribute set, where the members of the attribute set are restricted to the given interface.
interfaceName
- The interface of which all members of this attribute set must be an instance. It is assumed to be interface Attribute
or a subinterface thereof.NullPointerException
- if interfaceName is null.protected HashAttributeSet(Attribute attribute, Class<?> interfaceName)
Construct a new attribute set, initially populated with the given attribute, where the members of the attribute set are restricted to the given interface.
attribute
- Attribute value to add to the set.interfaceName
- The interface of which all members of this attribute set must be an instance. It is assumed to be interface Attribute
or a subinterface thereof.NullPointerException
- (unchecked exception) Thrown if attribute
is null.NullPointerException
- if interfaceName is null.ClassCastException
- (unchecked exception) Thrown if attribute
is not an instance of interfaceName
.protected HashAttributeSet(Attribute[] attributes, Class<?> interfaceName)
Construct a new attribute set, where the members of the attribute set are restricted to the given interface. The new attribute set is populated by adding the elements of attributes
array to the set in sequence, starting at index 0. Thus, later array elements may replace earlier array elements if the array contains duplicate attribute values or attribute categories.
attributes
- Array of attribute values to add to the set. If null, an empty attribute set is constructed.interfaceName
- The interface of which all members of this attribute set must be an instance. It is assumed to be interface Attribute
or a subinterface thereof.NullPointerException
- (unchecked exception) Thrown if any element of attributes
is null.NullPointerException
- if interfaceName is null.ClassCastException
- (unchecked exception) Thrown if any element of attributes
is not an instance of interfaceName
.protected HashAttributeSet(AttributeSet attributes, Class<?> interfaceName)
Construct a new attribute set, initially populated with the values from the given set where the members of the attribute set are restricted to the given interface.
attributes
- set of attribute values to initialise the set. If null, an empty attribute set is constructed.interfaceName
- The interface of which all members of this attribute set must be an instance. It is assumed to be interface Attribute
or a subinterface thereof.ClassCastException
- (unchecked exception) Thrown if any element of attributes
is not an instance of interfaceName
.public Attribute get(Class<?> category)
Returns the attribute value which this attribute set contains in the given attribute category. Returns null
if this attribute set does not contain any attribute value in the given attribute category.
get
in interface AttributeSet
category
- Attribute category whose associated attribute value is to be returned. It must be a Class
that implements interface Attribute
.null
if this attribute set does not contain any attribute value in the given attribute category.NullPointerException
- (unchecked exception) Thrown if the category
is null.ClassCastException
- (unchecked exception) Thrown if the category
is not a Class
that implements interface Attribute
.public boolean add(Attribute attribute)
Adds the specified attribute to this attribute set if it is not already present, first removing any existing in the same attribute category as the specified attribute value.
add
in interface AttributeSet
attribute
- Attribute value to be added to this attribute set.true
if this attribute set changed as a result of the call, i.e., the given attribute value was not already a member of this attribute set.NullPointerException
- (unchecked exception) Thrown if the attribute
is null.UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support the add()
operation.public boolean remove(Class<?> category)
Removes any attribute for this category from this attribute set if present. If category
is null, then remove()
does nothing and returns false
.
remove
in interface AttributeSet
category
- Attribute category to be removed from this attribute set.true
if this attribute set changed as a result of the call, i.e., the given attribute category had been a member of this attribute set.UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support the remove()
operation.public boolean remove(Attribute attribute)
Removes the specified attribute from this attribute set if present. If attribute
is null, then remove()
does nothing and returns false
.
remove
in interface AttributeSet
attribute
- Attribute value to be removed from this attribute set.true
if this attribute set changed as a result of the call, i.e., the given attribute value had been a member of this attribute set.UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support the remove()
operation.public boolean containsKey(Class<?> category)
Returns true
if this attribute set contains an attribute for the specified category.
containsKey
in interface AttributeSet
category
- whose presence in this attribute set is to be tested.true
if this attribute set contains an attribute value for the specified category.public boolean containsValue(Attribute attribute)
Returns true
if this attribute set contains the given attribute.
containsValue
in interface AttributeSet
attribute
- value whose presence in this attribute set is to be tested.true
if this attribute set contains the given attribute value.public boolean addAll(AttributeSet attributes)
Adds all of the elements in the specified set to this attribute. The outcome is the same as if the add(Attribute)
operation had been applied to this attribute set successively with each element from the specified set. The behavior of the addAll(AttributeSet)
operation is unspecified if the specified set is modified while the operation is in progress.
If the addAll(AttributeSet)
operation throws an exception, the effect on this attribute set's state is implementation dependent; elements from the specified set before the point of the exception may or may not have been added to this attribute set.
addAll
in interface AttributeSet
attributes
- whose elements are to be added to this attribute set.true
if this attribute set changed as a result of the call.UnmodifiableSetException
- (Unchecked exception) Thrown if this attribute set does not support the addAll(AttributeSet)
method.NullPointerException
- (Unchecked exception) Thrown if some element in the specified set is null, or the set is null.add(Attribute)
public int size()
Returns the number of attributes in this attribute set. If this attribute set contains more than Integer.MAX_VALUE
elements, returns Integer.MAX_VALUE
.
size
in interface AttributeSet
public Attribute[] toArray()
Description copied from interface: AttributeSet
Returns an array of the attributes contained in this set.
toArray
in interface AttributeSet
public void clear()
Removes all attributes from this attribute set.
clear
in interface AttributeSet
UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support the clear()
operation.public boolean isEmpty()
Returns true if this attribute set contains no attributes.
isEmpty
in interface AttributeSet
public boolean equals(Object object)
Compares the specified object with this attribute set for equality. Returns true
if the given object is also an attribute set and the two attribute sets contain the same attribute category-attribute value mappings. This ensures that the equals()
method works properly across different implementations of the AttributeSet interface.
equals
in interface AttributeSet
equals
in class Object
object
- to be compared for equality with this attribute set.true
if the specified object is equal to this attribute set.Object.hashCode()
, HashMap
public int hashCode()
Returns the hash code value for this attribute set. The hash code of an attribute set is defined to be the sum of the hash codes of each entry in the AttributeSet. This ensures that t1.equals(t2)
implies that t1.hashCode()==t2.hashCode()
for any two attribute sets t1
and t2
, as required by the general contract of Object.hashCode()
.
hashCode
in interface AttributeSet
hashCode
in class Object
Object.equals(java.lang.Object)
, System.identityHashCode(java.lang.Object)
© 1993–2017, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.