JDK6的新特性

 

JDK6的新特性

关键字: jdk
JDK6的新特性
JDK6的新特性之一_Desktop类和SystemTray类
JDK6的新特性之七_用Console开发控制台程序
JDK6的新特性之三_理解StAX
JDK6的新特性之九_CommonAnnotations
JDK6的新特性之二_使用JAXB2来实现对象与XML之间的映射
JDK6的新特性之五_轻量级HttpServer
JDK6的新特性之八_嵌入式数据库Derby
JDK6的新特性之六_插入式注解处理API
JDK6的新特性之十_Web服务元数据
JDK6的新特性之十一_更简单强大的JAX-WS
JDK6的新特性之十三_JTable的排序和过滤
JDK6的新特性之十二_脚本语言支持
JDK6的新特性之四_使用Compiler API


JDK6的新特性之一_Desktop类和SystemTray类

JDK6.0发布有段时间了,新的JDK也有不少新的特性,我去网上搜集了一下,列在下面和大家一起学习.
1.Desktop和SystemTray. 在JDK6中 ,AWT新增加了两个类:Desktop和SystemTray,前者可以用来打开系统默认浏览器浏览指定的URL,打开系统默认邮件客户端给指定的邮箱发邮件,用默认应用程序打开或编辑文件(比如,用记事本打开以txt为后缀名的文件),用系统默认的打印机打印文档;后者可以用来在系统托盘区创建一个托盘程序。

我随便找了几张图,在Tray里面都是空的,没有图,可能是图太大,有xdjm知道希望告诉我.


Java代码
  1. importjava.awt.AWTException;
  2. importjava.awt.Desktop;
  3. importjava.awt.Image;
  4. importjava.awt.MenuItem;
  5. importjava.awt.PopupMenu;
  6. importjava.awt.SystemTray;
  7. importjava.awt.Toolkit;
  8. importjava.awt.TrayIcon;
  9. importjava.awt.event.ActionEvent;
  10. importjava.awt.event.ActionListener;
  11. importjava.io.File;
  12. importjava.io.IOException;
  13. importjava.net.URI;
  14. importjava.net.URISyntaxException;
  15. publicclassDesktopTrayTest{
  16. privatestaticDesktopdesktop;
  17. privatestaticSystemTrayst;
  18. privatestaticPopupMenupm;
  19. publicstaticvoidmain(String[]args){
  20. if(Desktop.isDesktopSupported()){
  21. desktop=Desktop.getDesktop();
  22. }
  23. if(SystemTray.isSupported()){
  24. st=SystemTray.getSystemTray();
  25. Imageimage=Toolkit.getDefaultToolkit().createImage("http://www.51ppt.com.cn/Article/Uploadphotos/200604/20064147333288.png");
  26. createPopupMenu();
  27. TrayIconti=newTrayIcon(image,"Demo",pm);
  28. try{
  29. st.add(ti);
  30. }catch(AWTExceptionawte){
  31. awte.printStackTrace();
  32. }
  33. }
  34. }
  35. publicstaticvoidsendMail(Stringmail){
  36. if(desktop!=null&&
  37. desktop.isSupported(Desktop.Action.MAIL)){
  38. try{
  39. desktop.mail(newURI(mail));
  40. }catch(IOExceptione){
  41. e.printStackTrace();
  42. }catch(URISyntaxExceptione){
  43. e.printStackTrace();
  44. }
  45. }
  46. }
  47. publicstaticvoidopenBrowser(Stringurl){
  48. if(desktop!=null&&
  49. desktop.isSupported(Desktop.Action.BROWSE)){
  50. try{
  51. desktop.browse(newURI(url));
  52. }catch(IOExceptione){
  53. e.printStackTrace();
  54. }catch(URISyntaxExceptione){
  55. e.printStackTrace();
  56. }
  57. }
  58. }
  59. publicstaticvoidedit(){
  60. if(desktop!=null&&
  61. desktop.isSupported(Desktop.Action.EDIT)){
  62. Filefile=newFile("test.txt");
  63. try{
  64. if(file.exists()==false){
  65. file.create();
  66. }
  67. desktop.edit(file);
  68. }catch(IOExceptionioe){
  69. ioe.printStackTrace();
  70. }
  71. }
  72. }
  73. publicstaticvoidcreatePopupMenu(){
  74. pm=newPopupMenu();
  75. MenuItemob=newMenuItem("Openurl");
  76. ob.addActionListener(newActionListener(){
  77. publicvoidactionPerformed(ActionEventae){
  78. openBrowser("http://blog.csdn.net/xumingming64398966");
  79. }
  80. });
  81. MenuItemsm=newMenuItem("SendMail");
  82. sm.addActionListener(newActionListener(){
  83. publicvoidactionPerformed(ActionEventae){
  84. sendMail("[email protected]");
  85. }
  86. });
  87. MenuItemed=newMenuItem("Edit");
  88. ed.addActionListener(newActionListener(){
  89. publicvoidactionPerformed(ActionEventae){
  90. edit();
  91. }
  92. });
  93. MenuItemex=newMenuItem("Exit");
  94. ex.addActionListener(newActionListener(){
  95. publicvoidactionPerformed(ActionEventae){
  96. System.exit(0);
  97. }
  98. });
  99. pm.add(ob);
  100. pm.add(sm);
  101. pm.add(ed);
  102. pm.addSeparator();
  103. pm.add(ex);
  104. }
  105. }

2.Console. JDK6中提供了java.io.Console类专用来访问基于字符的控制台设备. 你的程序如果要与Windows下的cmd或者Linux下的Terminal交互,就可以用Console类代劳. 但我们不总是能得到可用的Console, 一个JVM是否有可用的Console依赖于底层平台和JVM如何被调用. 如果JVM是在交互式命令行(比如Windows的cmd)中启动的,并且输入输出没有重定向到另外的地方,那么就可以得到一个可用的Console实例. 下面代码演示了Console类的用法:

 

Java代码
  1. importjava.io.Console;
  2. publicclassConsoleTest{
  3. publicstaticvoidmain(String[]args){
  4. Consoleconsole=System.console();
  5. if(console!=null){
  6. Stringuser=newString(console.readLine("EnterUser:",newObject[0]));
  7. Stringpwd=newString(console.readPassword("EnterPassword:",newObject[0]));
  8. console.printf("Usernameis:%s",newObject[]{user});
  9. console.printf("Passwordis:%s",newObject[]{pwd});
  10. }else{
  11. System.out.println("NoConsole!");
  12. }
  13. }
  14. }

 

你如果是在一个IDE中如eclipse, netbeans中运行你将得到:
No Console!
因为只有在命令行中才能得到Console对象。

 

3.Compiler API. 现在我们可以用JDK6 的Compiler API(JSR 199)去动态编译Java源文件,Compiler API结合反射功能就可以实现动态的产生Java代码并编译执行这些代码,有点动态语言的特征。这个特性对于某些需要用到动态编译的应用程序相当有用,比如JSP Web Server,当我们手动修改JSP后,是不希望需要重启Web Server才可以看到效果的,这时候我们就可以用Compiler API来实现动态编译JSP文件,当然,现在的JSP Web Server也是支持JSP热部署的,现在的JSP Web Server通过在运行期间通过Runtime.exec或ProcessBuilder来调用javac来编译代码,这种方式需要我们产生另一个进程去做编译工作,不够优雅而且容易使代码依赖与特定的操作系统;Compiler API通过一套易用的标准的API提供了更加丰富的方式去做动态编译,而且是跨平台的。 下面代码演示了Compiler API的使用:

 

Java代码
  1. importjava.io.BufferedWriter;
  2. importjava.io.FileWriter;
  3. importjava.io.IOException;
  4. importjava.util.Iterator;
  5. importjavax.tools.JavaCompiler;
  6. importjavax.tools.JavaFileObject;
  7. importjavax.tools.StandardJavaFileManager;
  8. importjavax.tools.ToolProvider;
  9. publicclassCompilerAPITest{
  10. privatefinalstaticStringsrcFileName="Test.java";
  11. privatefinalstaticStringclassFileName="Test.class";
  12. privatefinalstaticStringclassName="Test";
  13. publicstaticvoidmain(String[]args){
  14. JavaCompilercompiler=ToolProvider.getSystemJavaCompiler();
  15. if(compiler==null){
  16. System.err.println("Compilerisnull!");
  17. return;
  18. }
  19. StandardJavaFileManagerfileManager=compiler.getStandardFileManager(null,null,null);
  20. generateJavaClass();
  21. Iterable<?extendsJavaFileObject>sourceFiles=fileManager.getJavaFileObjects(newString[]{srcFileName});
  22. compiler.getTask(null,fileManager,null,null,null,sourceFiles).call();
  23. try{
  24. fileManager.close();
  25. Class.forName(className).newInstance();
  26. }catch(IOExceptione){
  27. e.printStackTrace();
  28. }catch(InstantiationExceptione){
  29. e.printStackTrace();
  30. }catch(IllegalAccessExceptione){
  31. e.printStackTrace();
  32. }catch(ClassNotFoundExceptione){
  33. e.printStackTrace();
  34. }
  35. }
  36. publicstaticvoidgenerateJavaClass(){
  37. try{
  38. FileWriterrw=newFileWriter(srcFileName);
  39. BufferedWriterbw=newBufferedWriter(rw);
  40. bw.write("publicclass"+className+"{");
  41. bw.newLine();
  42. bw.write("public"+className+"(){");
  43. bw.newLine();
  44. bw.write("System.out.println('youareintheconstructorofClassTest');");
  45. bw.write("}");
  46. bw.newLine();
  47. bw.write("}");
  48. bw.flush();
  49. bw.close();
  50. }catch(IOExceptione){
  51. e.printStackTrace();
  52. }
  53. }
  54. }

 

JDK1.6.0新特性详解与代码示例

 

JDK6.0发布有段时间了,新的JDK也有不少新的特性,我去网上搜集了一下,列在下面和大家一起学习.
1.Desktop和SystemTray. 在JDK6中 ,AWT新增加了两个类:Desktop和SystemTray,前者可以用来打开系统默认浏览器浏览指定的URL,打开系统默认邮件客户端给指定的邮箱发邮件,用默认应用程序打开或编辑文件(比如,用记事本打开以txt为后缀名的文件),用系统默认的打印机打印文档;后者可以用来在系统托盘区创建一个托盘程序。

我随便找了几张图,在Tray里面都是空的,没有图,可能是图太大,有xdjm知道希望告诉我.


import java.awt.AWTException;
import java.awt.Desktop;
import java.awt.Image;
import java.awt.MenuItem;
import java.awt.PopupMenu;
import java.awt.SystemTray;
import java.awt.Toolkit;
import java.awt.TrayIcon;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.File;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;

public class DesktopTrayTest {
private static Desktop desktop;
private static SystemTray st;
private static PopupMenu pm;

public static void main( String[] args ) {
if( Desktop.isDesktopSupported() ) {
desktop = Desktop.getDesktop();
}
if( SystemTray.isSupported() ) {
st = SystemTray.getSystemTray();
Image image = Toolkit.getDefaultToolkit().createImage( "http://www.51ppt.com.cn/Article/Uploadphotos/200604/20064147333288.png" );
createPopupMenu();
TrayIcon ti = new TrayIcon( image, "Demo", pm );
try{
st.add( ti );
} catch( AWTException awte ) {
awte.printStackTrace();
}
}
}
public static void sendMail( String mail ) {
if( desktop != null &&
desktop.isSupported( Desktop.Action.MAIL ) ) {
try {
desktop.mail( new URI( mail ) );
} catch (IOException e) {
e.printStackTrace();
} catch (URISyntaxException e) {
e.printStackTrace();
}
}
}
public static void openBrowser( String url ) {
if( desktop != null &&
desktop.isSupported( Desktop.Action.BROWSE )) {
try {
desktop.browse( new URI( url ) );
} catch (IOException e) {
e.printStackTrace();
} catch (URISyntaxException e) {
e.printStackTrace();
}
}
}
public static void edit() {
if( desktop != null &&
desktop.isSupported( Desktop.Action.EDIT ) ) {
File file = new File( "test.txt" );
try {
if( file.exists() == false ) {
file.create();
}
desktop.edit( file );
} catch( IOException ioe ) {
ioe.printStackTrace();
}
}
}
public static void createPopupMenu() {
pm = new PopupMenu();
MenuItem ob = new MenuItem( "Open url" );
ob.addActionListener( new ActionListener() {
public void actionPerformed( ActionEvent ae ) {
openBrowser( "http://blog.csdn.net/xumingming64398966" );
}
});
MenuItem sm = new MenuItem( "Send Mail" );
sm.addActionListener( new ActionListener() {
public void actionPerformed( ActionEvent ae ) {
sendMail( "[email protected]" );
}
});
MenuItem ed = new MenuItem( "Edit" );
ed.addActionListener( new ActionListener() {
public void actionPerformed( ActionEvent ae ) {
edit();
}
});
MenuItem ex = new MenuItem( "Exit" );
ex.addActionListener( new ActionListener() {
public void actionPerformed( ActionEvent ae ) {
System.exit( 0 );
}
});
pm.add( ob );
pm.add( sm );
pm.add( ed );
pm.addSeparator();
pm.add( ex );
}
}

 

2.Console. JDK6中提供了java.io.Console类专用来访问基于字符的控制台设备. 你的程序如果要与Windows下的cmd或者Linux下的Terminal交互,就可以用Console类代劳. 但我们不总是能得到可用的Console, 一个JVM是否有可用的Console依赖于底层平台和JVM如何被调用. 如果JVM是在交互式命令行(比如Windows的cmd)中启动的,并且输入输出没有重定向到另外的地方,那么就可以得到一个可用的Console实例. 下面代码演示了Console类的用法:


import java.io.Console;

public class ConsoleTest {
public static void main( String[] args ) {
Console console = System.console();
if( console != null ) {
String user = new String( console.readLine( "Enter User:", new Object[ 0 ] ) );
String pwd = new String( console.readPassword( "Enter Password:", new Object[ 0 ] ));
console.printf( "User name is:%s", new Object[]{user} );
console.printf( "Password is:%s", new Object[]{pwd} );
} else {
System.out.println( "No Console!" );
}
}
}


你如果是在一个IDE中如eclipse, netbeans中运行你将得到:
No Console!
因为只有在命令行中才能得到Console对象。

3.Compiler API. 现在我们可以用JDK6 的Compiler API(JSR 199)去动态编译Java源文件,Compiler API结合反射功能就可以实现动态的产生Java代码并编译执行这些代码,有点动态语言的特征。这个特性对于某些需要用到动态编译的应用程序相当有用,比如JSP Web Server,当我们手动修改JSP后,是不希望需要重启Web Server才可以看到效果的,这时候我们就可以用Compiler API来实现动态编译JSP文件,当然,现在的JSP Web Server也是支持JSP热部署的,现在的JSP Web Server通过在运行期间通过Runtime.exec或ProcessBuilder来调用javac来编译代码,这种方式需要我们产生另一个进程去做编译工作,不够优雅而且容易使代码依赖与特定的操作系统;Compiler API通过一套易用的标准的API提供了更加丰富的方式去做动态编译,而且是跨平台的。 下面代码演示了Compiler API的使用:


import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.util.Iterator;

import javax.tools.JavaCompiler;
import javax.tools.JavaFileObject;
import javax.tools.StandardJavaFileManager;
import javax.tools.ToolProvider;

public class CompilerAPITest {
private final static String srcFileName = "Test.java";
private final static String classFileName = "Test.class";
private final static String className = "Test";

public static void main( String[] args ) {
JavaCompiler compiler = ToolProvider.getSystemJavaCompiler();
if( compiler == null ) {
System.err.println( "Compiler is null!" );
return;
}
StandardJavaFileManager fileManager = compiler.getStandardFileManager( null, null, null );
generateJavaClass();

Iterable < ? extends JavaFileObject> sourceFiles = fileManager.getJavaFileObjects( new String[]{ srcFileName } );
compiler.getTask( null, fileManager, null, null, null, sourceFiles ).call();
try {
fileManager.close();
Class.forName( className ).newInstance();
} catch (IOException e) {
e.printStackTrace();
} catch (InstantiationException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}

public static void generateJavaClass() {
try {
FileWriter rw = new FileWriter( srcFileName );
BufferedWriter bw = new BufferedWriter( rw );
bw.write( "public class " + className + " {" );
bw.newLine();

bw.write( "public " + className + "() {");
bw.newLine();
bw.write( "System.out.println( 'you are in the constructor of Class Test' );" );
bw.write( "}" );
bw.newLine();

bw.write( "}" );
bw.flush();
bw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}

我在运行这个例子的时候发现ToolProvider.getSystemJavaCompiler得到的是NULL,后来上网一查,原来是一个Bug!链接如下:
http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6477844

Closed, not reproducible
那为什么我一直在reproduce阿?

4.Http Server API. JDK6提供了一个简单的Http Server API,据此我们可以构建自己的嵌入式Http Server,它支持Http和Https协议,提供了HTTP1.1的部分实现,没有被实现的那部分可以通过扩展已有的Http Server API来实现,程序员必须自己实现HttpHandler接口,HttpServer会调用HttpHandler实现类的回调方法来处理客户端请求,在这里,我们把一个Http请求和它的响应称为一个交换,包装成HttpExchange类,HttpServer负责将HttpExchange传给 HttpHandler实现类的回调方法.下面代码演示了怎样创建自己的Http Server .
Java代码
  1. importjava.io.IOException;
  2. importjava.io.InputStream;
  3. importjava.io.OutputStream;
  4. importjava.net.InetSocketAddress;
  5. importcom.sun.net.httpserver.HttpExchange;
  6. importcom.sun.net.httpserver.HttpHandler;
  7. importcom.sun.net.httpserver.HttpServer;
  8. publicclassHttpServerAPITest{
  9. privatestaticintcount=0;
  10. publicstaticvoidmain(String[]args){
  11. try{
  12. HttpServerhs=HttpServer.create(newInetSocketAddress(8888),0);
  13. hs.createContext("/",newMyHandler());
  14. hs.createContext("/java",newMyHandler());
  15. hs.setExecutor(null);
  16. hs.start();
  17. System.out.println("---begin---");
  18. System.out.println("Listeningon"+hs.getAddress());
  19. }catch(IOExceptionioe){
  20. ioe.printStackTrace();
  21. }
  22. }
  23. staticclassMyHandlerimplementsHttpHandler{
  24. publicvoidhandle(HttpExchangehe)throwsIOException{
  25. System.out.println("Request"+count++);
  26. System.out.println(he.getHttpContext().getPath());
  27. InputStreamis=he.getRequestBody();
  28. Stringresponse="<fontcolor='blue'>HappySpringFesterval</font>";
  29. he.sendResponseHeaders(200,response.length());
  30. OutputStreamos=he.getResponseBody();
  31. os.write(response.getBytes());
  32. os.close();
  33. }
  34. }
  35. }

 

5.对脚本语言的支持如: ruby, groovy, javascript.
Java代码
  1. importjava.io.FileReader;
  2. importjavax.script.Invocable;
  3. importjavax.script.ScriptEngine;
  4. importjavax.script.ScriptEngineManager;
  5. publicclassScriptTest{
  6. publicstaticvoidmain(String[]args){
  7. ScriptEngineManagermanager=newScriptEngineManager();
  8. ScriptEngineengine=manager.getEngineByName("ECMAScript");
  9. try{
  10. engine.eval(newFileReader("C:/test.js"));
  11. InvocableinvocableEngine=(Invocable)engine;
  12. Objectret=invocableEngine.invokeFunction("test",null);
  13. System.out.println("Theresultis:"+(Double)ret);
  14. }catch(Exceptione){
  15. e.printStackTrace();
  16. }
  17. }
  18. }
  19. test.js如下:
  20. functiontest(){
  21. returnMath.round(11.2);
  22. }

6.插入式注解处理API(Pluggable Annotation Processing API),插入式注解处理API(JSR 269)提供一套标准API来处理Annotations.JSR 269用Annotation Processor在编译期间而不是运行期间处理Annotation, Annotation Processor相当于编译器的一个插件,所以称为插入式注解处理.如果Annotation Processor处理Annotation时(执行process方法)产生了新的Java代码,编译器会再调用一次Annotation Processor,如果第二次处理还有新代码产生,就会接着调用Annotation Processor,直到没有新代码产生为止.每执行一次process()方法被称为一个"round",这样整个Annotation processing过程可以看作是一个round的序列.
举个例子:们想建立一套基于Annotation的单元测试框架(如TestNG),在测试类里面用Annotation来标识测试期间需要执行的测试方法,如下所示:

Java代码
  1. @TestMethod
  2. publicvoidtestCheckName(){
  3. //dosomethinghere
  4. }

 

这时我们就可以用JSR 269提供的API来处理测试类,根据Annotation提取出需要执行的测试方法.


再举个例子: 下面我用代码演示如何来用JSR 269提供的API来处理Annotations和读取Java源文件的元数据(metadata)

Java代码
  1. importjava.util.List;
  2. importjava.util.Map;
  3. importjava.util.Set;
  4. importjavax.annotation.processing.AbstractProcessor;
  5. importjavax.annotation.processing.RoundEnvironment;
  6. importjavax.annotation.processing.SupportedAnnotationTypes;
  7. importjavax.annotation.processing.SupportedSourceVersion;
  8. importjavax.lang.model.SourceVersion;
  9. importjavax.lang.model.element.AnnotationMirror;
  10. importjavax.lang.model.element.AnnotationValue;
  11. importjavax.lang.model.element.Element;
  12. importjavax.lang.model.element.ExecutableElement;
  13. importjavax.lang.model.element.TypeElement;
  14. importjavax.lang.model.util.ElementFilter;
  15. importjavax.tools.Diagnostic.Kind;
  16. @SupportedAnnotationTypes("ToBeTested")
  17. @SupportedSourceVersion(SourceVersion.RELEASE_6)
  18. publicclassMyAnnotationProcessorextendsAbstractProcessor{
  19. privatevoidnote(Stringmsg){
  20. processingEnv.getMessager().printMessage(Kind.NOTE,msg);
  21. }
  22. publicbooleanprocess(Set<?extendsTypeElement>annotations,RoundEnvironmentroundEnv){
  23. for(TypeElementte:annotations){
  24. note("annotation:"+te.toString());
  25. }
  26. Set<?extendsElement>elements=roundEnv.getRootElements();
  27. for(Elemente:elements){
  28. List<?extendsElement>enclosedElems=e.getEnclosedElements();
  29. List<?extendsExecutableElement>ees=ElementFilter.methodsIn(enclosedElems);
  30. for(ExecutableElementee:ees){
  31. note("ExecutableElementName:"+ee.getSimpleName());
  32. List<?extendsAnnotationMirror>as=ee.getAnnotationMirrors();
  33. note("as:"+as);
  34. for(AnnotationMirroram:as){
  35. Map<?extendsExecutableElement,?extendsAnnotationValue>map=am.getElementValues();
  36. Set<?extendsExecutableElement>ks=map.keySet();
  37. for(ExecutableElementk:ks){
  38. AnnotationValueav=map.get(k);
  39. note("----"+ee.getSimpleName()+"."+k.getSimpleName()+"="+av.getValue());
  40. }
  41. }
  42. }
  43. }
  44. returnfalse;
  45. }
  46. }
  47. publicclassTesting{
  48. @ToBeTested(group="A")
  49. publicvoidm1(){
  50. }
  51. @ToBeTested(group="B",owner="QQ")
  52. publicvoidm2(){
  53. }
  54. }
  55. importjava.lang.annotation.ElementType;
  56. importjava.lang.annotation.Retention;
  57. importjava.lang.annotation.RetentionPolicy;
  58. importjava.lang.annotation.Target;
  59. @Retention(RetentionPolicy.RUNTIME)
  60. @Target(ElementType.METHOD)
  61. public@interfaceToBeTested{
  62. Stringowner()default"Chinajash";
  63. Stringgroup();
  64. }

7.StAX. StAX是The Streaming API for XML的缩写,是继DOM(Document Object Model)和SAX(Simple API for XML)之后的又一种处理xml的api,一种利用拉模式解析(pull-parsing)XML文档的API.StAX通过提供一种基于事件迭代器(Iterator)的API让程序员去控制xml文档解析过程,程序遍历这个事件迭代器去处理每一个解析事件,解析事件可以看做是程序拉出来的,也就是程序促使解析器产生一个解析事件然后处理该事件,之后又促使解析器产生下一个解析事件,如此循环直到碰到文档结束符;SAX也是基于事件处理xml文档,但却是用推模式解析,解析器解析完整个xml文档后,才产生解析事件,然后推给程序去处理这些事件;DOM采用的方式是将整个xml文档映射到一颗内存树,这样就可以很容易地得到父节点和子结点以及兄弟节点的数据,但如果文档很大,将会严重影响性能。

下面是个例子:
Java代码
  1. importjava.io.FileNotFoundException;
  2. importjava.io.FileOutputStream;
  3. importjavax.xml.namespace.QName;
  4. importjavax.xml.stream.XMLEventReader;
  5. importjavax.xml.stream.XMLInputFactory;
  6. importjavax.xml.stream.XMLOutputFactory;
  7. importjavax.xml.stream.XMLStreamException;
  8. importjavax.xml.stream.XMLStreamWriter;
  9. importjavax.xml.stream.events.StartElement;
  10. importjavax.xml.stream.events.XMLEvent;
  11. publicclassStaxTest{
  12. publicstaticvoidmain(String[]arg)throwsXMLStreamException,FileNotFoundException{
  13. readXMLByStAX();
  14. writeXMLByStAX();
  15. }
  16. publicstaticvoidreadXMLByStAX()throwsXMLStreamException,FileNotFoundException{
  17. XMLInputFactoryfactory=XMLInputFactory.newInstance();
  18. XMLEventReaderreader=factory.createXMLEventReader(StaxTest.class.getResourceAsStream("test.xml"));
  19. XMLEventevent;
  20. StringBufferparsingResult=newStringBuffer();
  21. while(reader.hasNext()){
  22. event=reader.nextEvent();
  23. if(event.isStartElement()){
  24. StartElementse=event.asStartElement();
  25. parsingResult.append("<");
  26. parsingResult.append(se.getName());
  27. if(se.getName().getLocalPart().equals("catalog")){
  28. parsingResult.append("id="");
  29. parsingResult.append(se.getAttributeByName(newQName("id")).getValue());
  30. parsingResult.append(""");
  31. }
  32. parsingResult.append(">");
  33. }elseif(event.isCharacters()){
  34. parsingResult.append(event.asCharacters().getData());
  35. }elseif(event.isEndElement()){
  36. parsingResult.append("</");
  37. parsingResult.append(event.asEndElement().getName());
  38. parsingResult.append(">");
  39. }
  40. }
  41. System.out.println(parsingResult);
  42. }
  43. publicstaticvoidwriteXMLByStAX()throwsXMLStreamException,FileNotFoundException{
  44. XMLOutputFactoryfactory=XMLOutputFactory.newInstance();
  45. XMLStreamWriterwriter=factory.createXMLStreamWriter(newFileOutputStream("output.xml"));
  46. writer.writeStartDocument();
  47. writer.writeCharacters("");
  48. writer.writeComment("testingcomment");
  49. writer.writeCharacters("");
  50. writer.writeStartElement("catalogs");
  51. writer.writeNamespace("myNS","http://blog.csdn.net/Chinajash");
  52. writer.writeAttribute("owner","sina");
  53. writer.writeCharacters("");
  54. writer.writeStartElement("http://blog.csdn.net/Chinajash","catalog");
  55. writer.writeAttribute("id","007");
  56. writer.writeCharacters("Apparel");
  57. //写入catalog元素的结束标签
  58. writer.writeEndElement();
  59. //写入catalogs元素的结束标签
  60. writer.writeEndElement();
  61. //结束XML文档
  62. writer.writeEndDocument();
  63. writer.close();
  64. }
  65. }
  66. test.xml:
  67. <?xmlversion="1.0"encoding="UTF-8"?>
  68. <catalogs>
  69. <catalogid="001">Book</catalog>
  70. <catalogid="002">Video</catalog>
  71. </catalogs>

 

8. Web Service. 由于Web服务日趋流行,利用Web服务的功能性的API特征正从最新的Java EE版本中向Java SE 6平台迁移。换言之,针对Web服务不需另外加入额外的工具,在Java EE和Java SE平台拥有相同的API。野马将大把不同的Web服务相关的API加到标准的工具柜中:以JSR 181针对Java 平台的Web服务元数据,通过JSR 224的基于XML 的Web服务Java API(JAX-WS);针对Java的带有附件的SOAP API(SAAJ)作为JSR 67 。与三个Web服务API相关的包新增到Java SE 6.0里:JAX-WS API 放置到javax.xml.ws包; SAAJ类在javax.xml.soap 包; Web服务的元数据类放置在javax.jws包里。 下面是一个简单的例子, 下面的代码是要作为web service发布的类。
Java代码
  1. packagehello;
  2. importjavax.jws.WebService;
  3. importjavax.xml.ws.Endpoint;
  4. @WebService
  5. publicclassCircleFunctions{
  6. publicdoublegetArea(intradius){
  7. returnMath.PI*radius*radius;
  8. }
  9. publicdoublegetCircumference(intradius){
  10. returnMath.PI*radius*2;
  11. }
  12. publicstaticvoidmain(String[]args){
  13. Endpoint.publish("http://localhost:8888/WebServiceExample/circlefunctions",newCircleFunctions());
  14. }
  15. }

 

处理的方法如下:
javac -d ./ CircleFunctions.java
wsgen hello.CircleFunctions
java hello.CircleFunctions
然后在浏览器中输入如下url,你将得到一个xml页面:
http: //localhost:8888/WebServiceExample/circlefunctions?WSDL

参考网页:
1.Desktop和SystemTray. http://dev.yesky.com/411/3019911.shtml
2.Console. http://dev.yesky.com/133/3032133.shtml
3.Compiler API. http://developer.51cto.com/art/200701/37359.htm
4.HttpServer API. http://www.testage.net/QA/Dev/200701/1396.htm
5. 对脚本语言的支持http://blog.edwardro.com/read.php?167
6. 插入式注解处理API. http://ourconan.com.cn/article.php?itemid-2113-type-blog.html
7.StAX. http://ourconan.com.cn/article.php?itemid-2111-type-blog.html
8.Web Service. http://www.360doc.com/showWeb/0/0/298124.aspx
9.JDK1.5的Annotation
http://lzqdiy.bokee.com/viewdiary.14724866.html

你可能感兴趣的:(jdk6)