public interface AttributeSet
Attribute.
 
 An attribute set contains a group of attribute values,
 where duplicate values are not allowed in the set.
 Furthermore, each value in an attribute set is
 a member of some category, and at most one value in any particular
 category is allowed in the set. For an attribute set, the values are Attribute objects, and the categories are Class objects. An attribute's category is the class (or interface) at the
 root of the class hierarchy for that kind of attribute. Note that an
 attribute object's category may be a superclass of the attribute object's
 class rather than the attribute object's class itself. An attribute
 object's
 category is determined by calling the getCategory() method defined in interface Attribute.
 
The interfaces of an AttributeSet resemble those of the Java Collections API's java.util.Map interface, but is more restrictive in the types it will accept, and combines keys and values into an Attribute.
 Attribute sets are used in several places in the Print Service API. In
 each context, only certain kinds of attributes are allowed to appear in the
 attribute set, as determined by the tagging interfaces which the attribute
 class implements -- DocAttribute, PrintRequestAttribute, PrintJobAttribute, and PrintServiceAttribute.
 There are four specializations of an attribute set that are restricted to
 contain just one of the four kinds of attribute -- DocAttributeSet, PrintRequestAttributeSet,
 PrintJobAttributeSet, and PrintServiceAttributeSet, respectively. Note that
 many attribute classes implement more than one tagging interface and so may
 appear in more than one context.
 
DocAttributeSet, containing DocAttributes, specifies the characteristics of an individual doc and the
 print job settings to be applied to an individual doc.
 
PrintRequestAttributeSet, containing
 PrintRequestAttributes, specifies the
 settings
 to be applied to a whole print job and to all the docs in the print job.
 
PrintJobAttributeSet, containing PrintJobAttributes, reports the status of a print job.
 
PrintServiceAttributeSet, containing
 PrintServiceAttributes, reports the status of
  a Print Service instance.
 In some contexts, the client is only allowed to examine an attribute set's contents but not change them (the set is read-only). In other places, the client is allowed both to examine and to change an attribute set's contents (the set is read-write). For a read-only attribute set, calling a mutating operation throws an UnmodifiableSetException.
 The Print Service API provides one implementation of interface
 AttributeSet, class HashAttributeSet.
 A client can use class HashAttributeSet or provide its own implementation of
 interface AttributeSet. The Print Service API also provides
 implementations of interface AttributeSet's subinterfaces -- classes HashDocAttributeSet,
 HashPrintRequestAttributeSet, HashPrintJobAttributeSet, and HashPrintServiceAttributeSet.
 
| Modifier and Type | Method | Description | 
|---|---|---|
| boolean | add(Attribute attribute) | Adds the specified attribute to this attribute set if it is not
 already present, first removing any existing value in the same
 attribute category as the specified attribute value. | 
| boolean | addAll(AttributeSet attributes) | Adds all of the elements in the specified set to this attribute. | 
| void | clear() | Removes all attributes from this attribute set. | 
| boolean | containsKey(Class<?> category) | Returns true if this attribute set contains an
 attribute for the specified category. | 
| boolean | containsValue(Attribute attribute) | Returns true if this attribute set contains the given
 attribute value. | 
| boolean | equals(Object object) | Compares the specified object with this attribute set for equality. | 
| Attribute | get(Class<?> category) | Returns the attribute value which this attribute set contains in the
 given attribute category. | 
| int | hashCode() | Returns the hash code value for this attribute set. | 
| boolean | isEmpty() | Returns true if this attribute set contains no attributes. | 
| boolean | remove(Attribute attribute) | Removes the specified attribute from this attribute set if
 present. | 
| boolean | remove(Class<?> category) | Removes any attribute for this category from this attribute set if
 present. | 
| int | size() | Returns the number of attributes in this attribute set. | 
| Attribute[] | toArray() | Returns an array of the attributes contained in this set. | 
Attribute get(Class<?> category)
category - Attribute category whose associated attribute value
                   is to be returned. It must be a
                   Class
                   that implements interface Attribute.NullPointerException - (unchecked exception) Thrown if the category is null.ClassCastException - (unchecked exception) Thrown if the category is not a
     Class that implements interface Attribute.boolean add(Attribute attribute)
attribute - Attribute value to be added to 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.boolean remove(Class<?> category)
category is null, then
 remove() does nothing and returns false.category - Attribute category to be removed from this
                  attribute set.UnmodifiableSetException - (unchecked exception) Thrown if this attribute set does not support
     the remove() operation.boolean remove(Attribute attribute)
attribute is null, then
 remove() does nothing and returns false.attribute - Attribute value to be removed from this attribute set.UnmodifiableSetException - (unchecked exception) Thrown if this attribute set does not support
     the remove() operation.boolean containsKey(Class<?> category)
category - whose presence in this attribute set is
            to be tested.boolean containsValue(Attribute attribute)
attribute - Attribute value whose presence in this
 attribute set is to be tested.boolean addAll(AttributeSet attributes)
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.
attributes - whose elements are to be added to this attribute
            set.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.add(Attribute)int size()
Attribute[] toArray()
void clear()
UnmodifiableSetException - (unchecked exception) Thrown if this attribute set does not support
     the clear() operation.boolean isEmpty()
boolean equals(Object object)
equals in class Objectobject - to be compared for equality with this attribute set.Object.hashCode(), 
HashMapint hashCode()
Object.hashCode().hashCode in class ObjectObject.equals(java.lang.Object), 
System.identityHashCode(java.lang.Object) Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.