java.lang.Objectjavax.print.attribute.EnumSyntax
All Implemented Interfaces:
Cloneable, Serializable
public class Bach extends EnumSyntax { public static final Bach JOHANN_SEBASTIAN = new Bach(0); public static final Bach WILHELM_FRIEDEMANN = new Bach(1); public static final Bach CARL_PHILIP_EMMANUEL = new Bach(2); public static final Bach JOHANN_CHRISTIAN = new Bach(3); public static final Bach P_D_Q = new Bach(4); private static final String[] stringTable = { "Johann Sebastian Bach", "Wilhelm Friedemann Bach", "Carl Philip Emmanuel Bach", "Johann Christian Bach", "P.D.Q. Bach" }; protected String[] getStringTable() { return stringTable; } private static final Bach[] enumValueTable = { JOHANN_SEBASTIAN, WILHELM_FRIEDEMANN, CARL_PHILIP_EMMANUEL, JOHANN_CHRISTIAN, P_D_Q }; protected EnumSyntax[] getEnumValueTable() { return enumValueTable; } }You can then write code that uses the
==
and !=
operators to test enumeration values; for example:
Bach theComposer; . . . if (theComposer == Bach.JOHANN_SEBASTIAN) { System.out.println ("The greatest composer of all time!"); }The
equals()
method for an enumeration class just does a test
for identical objects (==
).
You can convert an enumeration value to a string by calling toString()
. The string is obtained from a table
supplied by the enumeration class.
Under the hood, an enumeration value is just an integer, a different integer
for each enumeration value within an enumeration class. You can get an
enumeration value's integer value by calling getValue()
. An enumeration value's integer value is established
when it is constructed (see EnumSyntax(int)
). Since the constructor is protected, the only
possible enumeration values are the singleton objects declared in the
enumeration class; additional enumeration values cannot be created at run
time.
You can define a subclass of an enumeration class that extends it with
additional enumeration values. The subclass's enumeration values' integer
values need not be distinct from the superclass's enumeration values' integer
values; the ==
, !=
, equals()
, and
toString()
methods will still work properly even if the subclass
uses some of the same integer values as the superclass. However, the
application in which the enumeration class and subclass are used may need to
have distinct integer values in the superclass and subclass.
David
- MendenhallAlan
- KaminskyConstructor: |
---|
|
Method from javax.print.attribute.EnumSyntax Summary: |
---|
clone, getEnumValueTable, getOffset, getStringTable, getValue, hashCode, readResolve, toString |
Methods from java.lang.Object: |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Method from javax.print.attribute.EnumSyntax Detail: |
---|
|
getOffset() and
N is the length of the enumeration value table. The element in the
enumeration value table at index i-L is the enumeration
value object whose integer value is i; the readResolve() method needs this to preserve singleton
semantics during deserialization of an enumeration instance. If an
integer within the above range is not used by any enumeration value,
leave the corresponding table element null.
The default implementation returns null. If the enumeration class (a
subclass of class EnumSyntax) does not override this method to return
a non-null enumeration value table, and the subclass does not override
the |
The default implementation returns 0. If the enumeration class (a subclass of class EnumSyntax) uses integer values starting at other than 0, override this method in the subclass. |
getOffset() and N is the length
of the string table. The element in the string table at index
i-L is the value returned by toString() for the enumeration value whose integer value
is i. If an integer within the above range is not used by any
enumeration value, leave the corresponding table element null.
The default implementation returns null. If the enumeration class (a
subclass of class EnumSyntax) does not override this method to return a
non-null string table, and the subclass does not override the |
|
|
|
|