1. Trang chủ
  2. » Công Nghệ Thông Tin

Java 6 Platform Revealed phần 10 docx

30 290 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 30
Dung lượng 490,35 KB

Nội dung

■Tip If you declare your own annotations, keep in mind the pattern shown here. Repeated annotations are not allowed, so they must be grouped together into a single annotation. The javax.annotation.processing Package The annotations found in the javax.annotation.processing package are used by the capa- bilities added with JSR 269 for annotation processing. There are three annotations there: SupportedAnnotationTypes, SupportedOptions, and SupportedSourceVersion. Each of these will be described later in the chapter, in the “Annotation Processing” section. The javax.management Package The two annotations found in the javax.management package are DescriptorKey and MXBean. If you are familiar with the Java Management Extensions, their usage will prove helpful. The DescriptorKey annotation is for describing annotation elements related to a field. For an attribute, operation, or construction, you can add descriptors such that when the resulting descriptor is created, you can configure its values. See the javadoc for the DescriptorKey annotation for more information about auto-conversion of annotation elements, such as rules for how a primitive becomes an object. The MXBean annotation is used to explicitly tag an interface as an MXBean interface or not. If the interface name ends in MXBean, it is an MXBean interface by default. If it doesn’t, then the interface isn’t an MXBean-related interface. The @MXBean annotation allows you to tag an interface as an MXBean if it doesn’t end with MXBean, and allows you to reject the automatic association if you don’t want it. For the positive case, the following three declarations in Listing 10-5 are defined to be MXBean interfaces, assuming proper imports. Listing 10-5. @MXBean Annotation Usage // Default naming public interface MyMXBean { } @MXBean public interface MyInterface1 { } @MXBean(true) public interface MyInterface2 { } CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 191 6609CH10.qxd 6/23/06 1:41 PM Page 191 For the negative cases, there are only two: // Default naming public interface MyClass { } @MXBean(false) public interface MyMXBean { } The javax.xml.bind.annotation Package The javax.xml.bind.annotation package is for customizing Java program elements to an XML Schema mapping, as shown in Chapter 6. It defines the annotations shown in Table 10-1. Table 10-1. Annotations Found in the javax.xml.bind.annotation Package Annotation Description XmlAccessorOrder Controls the ordering of fields and properties in a class XmlAccessorType Controls whether fields or JavaBean properties are serialized by default XmlAnyAttribute Maps a JavaBean property to a map of wildcard attributes XmlAnyElement Maps a JavaBean property to an XML infoset representation and/or JAXB element XmlAttachmentRef Marks a field/property to indicate that its XML form is a URI reference to mime content XmlAttribute Maps a JavaBean property to an XML attribute XmlElement Maps a JavaBean property to an XML element derived from the property name XmlElementDecl Maps a factory method to an XML element XmlElementRef Maps a JavaBean property to an XML element derived from the property’s type XmlElementRefs Marks a property that refers to classes with XmlElement or JAXBElement XmlElements Contains multiple @XmlElement annotations XmlElementWrapper Generates a wrapper element around an XML representation XmlEnum Maps an enumeration of type Enum to an XML representation XmlEnumValue Maps an enumerated constant in an Enum type to XML representation XmlID Maps a JavaBean property to XML ID CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES192 6609CH10.qxd 6/23/06 1:41 PM Page 192 Annotation Description XmlIDREF Maps a JavaBean property to XML IDREF XmlInlineBinaryData Disables consideration of XOP encoding for data types that are bound to base64-encoded binary data in XML XmlList Maps a property to a list simple type XmlMimeType Associates the mime type that controls the XML representation of the property XmlMixed Annotates a JavaBean multivalued property to support mixed content XmlNs Associates a namespace prefix with an XML namespace URI XmlRegistry Marks a class that has XML element factories XmlRootElement Maps a class or an enumerated type to an XML element XmlSchema Maps a package name to an XML namespace XmlSchemaType Maps a Java type to a simple schema built-in type XmlSchemaTypes Contains multiple @XmlSchemaType annotations XmlTransient Prevents the mapping of a JavaBean property to an XML representation XmlType Maps a class or an Enum type to an XML Schema type XmlValue Enables mapping a class to an XML Schema complex type with a simpleContent type or an XML Schema simple type The javax.xml.bind.annotation.adapters Package The javax.xml.bind.annotation.adapters package is for allowing Java classes to be used with JAXB. Again, this was shown in Chapter 6. There are two annotations in this package: • XmlJavaTypeAdapter • XmlJavaTypeAdapters The javax.xml.ws Package There are nine annotations found in the javax.xml.ws package. They are as follows: • BindingType • RequestWrapper • ResponseWrapper CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 193 6609CH10.qxd 6/23/06 1:41 PM Page 193 • ServiceMode • WebEndpoint • WebFault • WebServiceClient • WebServiceProvider • WebServiceRef These annotations are part of the core Java API for XML Web Services (JAX-WS) APIs. These were also explored in Chapter 6. Annotation Processing Enough about what annotations are out there. Let’s take a look at what you can do with them when writing them yourself. First, we’ll take a quick look at the 5.0 way of annota- tion processing. Then we’ll move on to the new way. J2SE 5.0 Processing The way to process annotations with J2SE 5.0 was to use a library called the Mirror API. The Mirror API contains two parts: one for the processor, in the com.sun.mirror.apt package; and the other for a series of support classes that model the language. The language modeling piece stays put for Java SE 6, while the apt pieces relocate to the javax.annotation.processing package, with a few changes. ■Note For information on the Mirror API, visit http://java.sun.com/j2se/1.5.0/docs/guide/ apt/mirror/overview-summary.html . It is now released under a BSD license and available at https://aptmirrorapi.dev.java.net. To learn about the language modeling piece, you’ll write a short little processor that walks through the classes found in the classpath and generates a list of all methods of all classes found. This doesn’t involve writing any new tags, just processing information already made available by the runtime environment. A slightly different form of this example is part of the documentation that comes with the apt tool. CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES194 6609CH10.qxd 6/23/06 1:41 PM Page 194 To get started, you need to create an implementation of the com.sun.mirror.apt. AnnotationProcessorFactory interface. There are three methods to the interface, as follows: • AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds, AnnotationProcessorEnvironment env) • Collection<String> supportedAnnotationTypes() • Collection<String> supportedOptions() ■Note For Java SE 6.0, the latter two methods here, supportedAnnotationTypes() and supportedOptions(), have become annotations themselves. The first method is what is used to “look up” the annotation processor. All the method needs to do is return a new instance of your class, which implements AnnotationProcessor. The processor interface implementation is the worker bee. It has a single method to implement: process(). If you use the AnnotationProcessorEnvironment implementation passed into the constructor of your AnnotationProcessor, your process() method loops through all the declarations requested. The AnnotationProcessorEnvironment offers different ways to request declarations. The Collection<Declaration> getDeclarationsAnnotatedWith(AnnotationTypeDeclaration a) method allows you to ask for those declarations (methods, classes, and fields) defined with a particular annotation. The Collection<TypeDeclaration> getSpecifiedType➥ Declarations() method essentially allows you to get all of them, giving you access to everything passed from the command line. Lastly, Collection<TypeDeclaration> getTypeDeclarations() doesn’t require you to specify everything. For the sample in Listing 10-6, use the getSpecifiedTypeDeclarations() variety. To process each declaration, you need a “visitor.” The com.sun.mirror.util package offers the DeclarationVisitor interface and SimpleDeclarationVisitor implementation to help. The DeclarationVisitor interface offers a series of visitXXXDeclaration() methods so that you can choose to work with only certain types of declarations, such as all the classes, all the interfaces, or all the methods. For instance, to print out the name of each class, you would override the visitClassDeclaration() method. public void visitClassDeclaration(ClassDeclaration d) { System.out.println(d.getQualifiedName()); } CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 195 6609CH10.qxd 6/23/06 1:41 PM Page 195 Listing 10-6 puts all the pieces together to define an annotation processor that prints out the specified classes and interfaces, along with the names of their methods (though not the constructors, which requires another visitXXXDeclaration() method implemented). Listing 10-6. J2SE 5.0 Annotation Processor import com.sun.mirror.apt.*; import com.sun.mirror.declaration.*; import com.sun.mirror.type.*; import com.sun.mirror.util.*; import static com.sun.mirror.util.DeclarationVisitors.*; import java.util.*; public class DumpFactory implements AnnotationProcessorFactory { // Process all annotations private static final Collection<String> supportedAnnotations = Collections.unmodifiableCollection(Arrays.asList("*")); // No options support private static final Collection<String> supportedOptions = Collections.emptySet(); public Collection<String> supportedAnnotationTypes() { return supportedAnnotations; } public Collection<String> supportedOptions() { return supportedOptions; } public AnnotationProcessor getProcessorFor(Set<AnnotationTypeDeclaration> atds, AnnotationProcessorEnvironment env) { return new DumpProcessor(env); } private static class DumpProcessor implements AnnotationProcessor { private final AnnotationProcessorEnvironment env; CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES196 6609CH10.qxd 6/23/06 1:41 PM Page 196 DumpProcessor(AnnotationProcessorEnvironment env) { this.env = env; } public void process() { for (TypeDeclaration typeDecl : env.getSpecifiedTypeDeclarations()) { typeDecl.accept(getDeclarationScanner(new DumpVisitor(), NO_OP)); } } private static class DumpVisitor extends SimpleDeclarationVisitor { public void visitMethodDeclaration(MethodDeclaration d) { System.out.println("\t" + d.getSimpleName()); } public void visitClassDeclaration(ClassDeclaration d) { System.out.println(d.getQualifiedName()); } public void visitInterfaceDeclaration(InterfaceDeclaration d) { System.out.println(d.getQualifiedName()); } } } } Defining the class is the easy part. Compiling it is just step one, and you can’t just use javac alone (yet). As previously mentioned, you need to include tools.jar in your class- path to compile an annotation. javac -cp c:\jdk1.6.0\lib\tools.jar DumpFactory.java ■Note At least for now, you have to manually include tools.jar in your classpath to compile annotation processors. It is possible that by the time Java SE 6 ships, that could change. Running of the annotation is not done with the java command. This is where apt comes into play. But before you can use apt, you have to package up the factory and processor into a JAR file and “install” it, like other items that use the service API. Typically, this is done by creating a file in META-INF/services named com.sun.mirror.apt. AnnotationProcessorFactory to point to the processor just defined. However, to avoid this step, you can include extra command-line options to the apt command. And, for a little test, just run the processor on itself. CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 197 6609CH10.qxd 6/23/06 1:41 PM Page 197 > apt -cp c:\jdk1.6.0\lib\tools.jar;. -factory DumpFactory DumpFactory.java DumpFactory supportedAnnotationTypes supportedOptions getProcessorFor DumpFactory.DumpProcessor process DumpFactory.DumpProcessor.DumpVisitor visitMethodDeclaration visitClassDeclaration visitInterfaceDeclaration Those are the basics of processing annotations with JDK 5.0. Java SE 6.0 Processing Moving to the Java SE 6.0 world changes a few things. The primary difference is the mov- ing of the annotation processing library into a more standard javax package and doing away with the factory. Secondly, the javac command-line tool now offers a -processor option to run a previously created processor. The removal of the factory is actually an interesting twist and makes total sense. All the factory did was return a single processor. So now the AbstractProcessor class forms the basis of all processors and really just is the processor—unlike with 5.0, in which you had to create an extra class. Ignoring the imports and a few other things, your basic processor definition is shown here: public class Dump6Processor extends AbstractProcessor { public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) { return false; // No annotations claimed } } To demonstrate, Listing 10-7 creates a processor that lists the annotations in the classes specified. This is where new the annotations of the javax.annotation.processing package are used: SupportedSourceVersion, SupportedAnnotationTypes, and SupportedOptions. The source version is specified by one of the constants of the SourceVersion enumeration of the java.lang.model package. The SupportedAnnotationTypes annotation is just like the supportedAnnotationTypes() method of the JDK 5.0 processor factory, and the SupportedOptions annotation mirrors supportedOptions(). When not specified, it defaults to returning an empty set. CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES198 6609CH10.qxd 6/23/06 1:41 PM Page 198 Beyond the annotations, all the processor does is loop through each annotation and print its name and nesting kind (level of declaration). More typically, if the annotation was something to be processed, you would use the accept() method on the TypeElement and “visit” it. Listing 10-7. Java SE 6.0 Annotation Processor import javax.annotation.processing.*; import javax.lang.model.*; import javax.lang.model.element.*; import java.util.*; // Source version @SupportedSourceVersion(SourceVersion.RELEASE_6) // Process all annotations @SupportedAnnotationTypes("*") // No options support // Empty set when not annotated with @SupportedOptions public class Dump6Processor extends AbstractProcessor { public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) { if (!roundEnv.processingOver()) { for (TypeElement element : annotations) { System.out.println(element.getQualifiedName() + "(" + element.getNestingKind() + ")"); } } return false; // No annotations claimed } } Again, compilation requires the tools.jar file, as follows: javac -cp c:\jdk1.6.0\lib\tools.jar Dump6Processor.java CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 199 6609CH10.qxd 6/23/06 1:41 PM Page 199 Now compile this with the -processor option to javac: > javac -processor Dump6Processor Dump6Processor.java javax.annotation.processing.SupportedSourceVersion(TOP_LEVEL) javax.annotation.processing.SupportedAnnotationTypes(TOP_LEVEL) warning: No annotation processors claimed present annotation types: [javax.annotation.processing.SupportedSourceVersion, javax.annotation.processing.SupportedAnnotationTypes] ■Note The javac command-line tool is getting “more” like java in Java SE 6.0 through the addition of command-line options. In fact, some are even nonstandard. Try out the -Xprint option with javac to get information similar to what you get from javap and -XprintRounds or -XprintProcessorInfo to monitor processing tasks. Options like -Xmaxerrs and -Xmaxwarns (which limit the maximum number of errors and warnings, respectively) are not new to Java SE 6.0. The processingOver() check in process() is necessary, as a processor could be called multiple times in one javac execution. More typically, a processor would actually do something with the annotation, such as generate a file. As far as generating the file, the old AnnotationProcessorEnvironment interface of the com.sun.mirror.apt package is now the new ProcessingEnvironment interface of the javax.annotation.processing package. In both cases, you get a Filer to hold the generated output. Writer out = env.getFiler().createTextFile( Filer.Location.SOURCE_TREE, package, path, charset) Summary Most people aren’t going to create their own annotation processors. They’re more apt to use annotations created by others, like for JDBC queries. If you only use them, you don’t need to know anything in this chapter. If you need to process annotations, however, you need to know how the processing model has changed from J2SE 5.0 to Java SE 6.0. It’s not that different—just slightly—with classes moving between packages and slightly different interfaces. Use them with care, and don’t go overboard. Defining your own annotations really has not changed from J2SE 5.0. Appendix A wraps up the book with information about acquiring the weekly releases. CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES200 6609CH10.qxd 6/23/06 1:41 PM Page 200 [...]... NoSuchElementException, 23 Queue interface, 22 removing elements from a deque, method sets, 22 66 09Index.qxd 6/ 23/ 06 1: 46 PM Page 215 ■INDEX JavaCompilerTool interface, 155–1 56, 158, 166 getSystemJavaCompilerTool() method, 155 getTask() method, 159– 160 , 162 JavaFileObject class, 162 JavaSourceFromString class, 166 javax.jws and javax.jws.soap packages adding @ tags to classes, methods and properties, 147 annotated... selection, code example, 69 –70 system tray, adding TrayIcon objects to, 65 system tray, uses for, 64 SystemTray class and the Singleton pattern, 65 SystemTray class, 64 , 67 using a system tray and tray icon, code example, 65 66 219 66 09Index.qxd 220 6/ 23/ 06 1: 46 PM Page 220 ■INDEX U URL encoding, 51 W Web Services Description Language (WSDL), 150 Web Services Metadata for the Java Platform, 147 wsgen (web... method, 162 getSystemJavaCompilerTool() method, 155 getting diagnostic messages from DiagnosticListener, 158 identifying the collection of items to compile, 159 implementing the public void report() method, 161 initiating the Java compiler from source, code example, 1 56 JavaCompilerTool class, getTask() method, 159– 160 , 162 JavaCompilerTool interface, 155–1 56, 158, 166 JavaFileObject class, 162 JavaSourceFromString... 24–29 66 09Index.qxd 6/ 23/ 06 1: 46 PM Page 211 ■INDEX E ECMAScript 1 .6 engine, 181 Extensible Markup Language (XML) Java API for XML-Based Web Services (JAX-WS) 2.0, 147, 150 Java Architecture for XML Binding (JAXB) 2.0, 115 javax.xml, table of package sizes, 1 16 Streaming API for XML (StAX), 115, 143 XML Digital Signature, 114, 132, 142 See also javax.xml.bind package; javax.xml.crypto package; javax.xml.soap... splash screen, image formats supported, 60 splash screen, specifying, 61 system tray, adding TrayIcon objects to, 65 system tray, uses for, 64 SystemTray class, 64 , 67 SystemTray class and the Singleton pattern, 65 table of package sizes, 57 tray icon, definition of, 65 using a system tray and tray icon, code example, 65 66 writing GIF images, code example, 76 java. io package checking available file... Installation takes some time 205 66 09AppA.qxd 2 06 6/23/ 06 1:42 PM Page 2 06 APPENDIX ■ LICENSING, INSTALLATION, AND PARTICIPATION Figure A -6 The documentation license agreement ■ Caution When I installed the javadoc, the “install complete” window would hide in the background and not come to the foreground I had to hunt it out to click OK to end the installation process 66 09AppA.qxd 6/ 23/ 06 1:42 PM Page 207 APPENDIX... methods, 108 Connection interface enhancements, 108 creating connections using a DataSource, 105 DataSet interface, 113 enhanced for loop, 105 , 113 enhanced functionality for BLOBs and CLOBs, 107 exception handling improvements, 105 handling multiple drivers for the same database connection, 105 java. sql and javax.sql packages, new features, 103 104 loading and registering database drivers, 104 looping... Attachments API for Java (SAAJ) 1.3, 147, 150–151 SOAPEnvelope object, 151 using AttachmentPart type objects, 150 javax.xml.stream package Cursor API, 143, 1 46 Cursor API, code example, 144 Iterator API, 143, 145–1 46 SAX parsing, 143 217 66 09Index.qxd 218 6/ 23/ 06 1: 46 PM Page 218 ■INDEX PooledConnection interface, 109 pre-Mustang loading of JDBC drivers, 105 registering a StatementEventListener, 109 requesting... 66 09Index.qxd 212 6/ 23/ 06 1: 46 PM Page 212 ■INDEX compiling with a DiagnosticListener, code example, 164 – 165 compiling with javac, extended lint option enabled, 163 DiagnosticCollector class, 158 DiagnosticCollector class, code example, 161 DiagnosticListener interface and compilation errors, 161 generating a compilation error, code example, 157 getJavaFileObjectsFromFiles() method, 162 getJavaFileObjectsFromStrings()... types, 6 MimetypesFileTypeMap subclass, 6 setDefaultCommandMap(), 5 215 66 09Index.qxd 2 16 6/23/ 06 1: 46 PM Page 2 16 ■INDEX reversing a string through ScriptEngine bindings, code example, 175–1 76 Runnable interface, 180 ScriptContext, 174 ScriptEngine, 172 ScriptEngineFactory objects, 172 ScriptEngineManager class, 172–173 table of package sizes, 171 throwing a ScriptException for script errors, 174, 176 . the tools.jar file, as follows: javac -cp c:jdk1 .6. 0lib ools.jar Dump6Processor .java CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES 199 66 09CH10.qxd 6/ 23/ 06 1:41 PM Page 199 Now compile. forums, at http://forums .java. net/jive/forum.jspa?forumID=23. APPENDIX ■ LICENSING, INSTALLATION, AND PARTICIPATION 207 66 09AppA.qxd 6/ 23/ 06 1:42 PM Page 207 66 09AppA.qxd 6/ 23/ 06 1:42 PM Page 208 A absolute. { private final AnnotationProcessorEnvironment env; CHAPTER 10 ■ PLUGGABLE ANNOTATION PROCESSING UPDATES1 96 660 9CH10.qxd 6/ 23/ 06 1:41 PM Page 1 96 DumpProcessor(AnnotationProcessorEnvironment env) { this.env

Ngày đăng: 06/08/2014, 02:20