- 浏览: 82405 次
- 性别:
- 来自: 杭州
最新评论
-
tian012:
thx a lot
淘宝Java中间件之路 -
yj10864:
很棒!
淘宝技术嘉年华 Java@Taobao PPT -
invincibleLiu:
这个文件如果包含了第三方依赖的话在vista下就不宜生成了,空 ...
VISTA下的Manifest文件,提升权限 -
vanadies10:
aixiangct 写道华黎?!您在微博还欠我一条回复呢,O( ...
北京之行,收获很多 -
vanadies10:
forchenyun 写道“淘宝会在今年的7月份在杭州举办淘宝 ...
北京之行,收获很多
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( "64398966@qq.com" );
}
});
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 .
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetSocketAddress;
import com.sun.net.httpserver.HttpExchange;
import com.sun.net.httpserver.HttpHandler;
import com.sun.net.httpserver.HttpServer;
public class HttpServerAPITest ...{
private static int count = 0;
public static void main( String[] args ) ...{
try ...{
HttpServer hs = HttpServer.create( new InetSocketAddress( 8888 ), 0 );
hs.createContext( "/", new MyHandler() );
hs.createContext( "/java", new MyHandler() );
hs.setExecutor( null );
hs.start();
System.out.println( "---begin---" );
System.out.println( "Listening on " + hs.getAddress() );
} catch( IOException ioe ) ...{
ioe.printStackTrace();
}
}
static class MyHandler implements HttpHandler ...{
public void handle( HttpExchange he ) throws IOException ...{
System.out.println( "Request " + count++ );
System.out.println( he.getHttpContext().getPath() );
InputStream is = he.getRequestBody();
String response = "<font color='blue'>Happy Spring Festerval</font>";
he.sendResponseHeaders( 200, response.length() );
OutputStream os = he.getResponseBody();
os.write( response.getBytes() );
os.close();
}
}
}
效果如图:
5.对脚本语言的支持如: ruby, groovy, javascript.
代码如下:
import java.io.FileReader;
import javax.script.Invocable;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
public class ScriptTest ...{
public static void main( String[] args ) ...{
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName( "ECMAScript" );
try ...{
engine.eval( new FileReader( "C:\test.js" ) );
Invocable invocableEngine = (Invocable)engine;
Object ret = invocableEngine.invokeFunction( "test", null );
System.out.println( "The result is :" + (Double)ret );
} catch( Exception e ) ...{
e.printStackTrace();
}
}
}
test.js如下:
function test()...{
return Math.round( 11.2 );
}
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来标识测试期间需要执行的测试方法,如下所示:
@TestMethod
public void testCheckName()...{
//do something here
}
这时我们就可以用JSR 269提供的API来处理测试类,根据Annotation提取出需要执行的测试方法.
再举个例子: 下面我用代码演示如何来用JSR 269提供的API来处理Annotations和读取Java源文件的元数据(metadata)
import java.util.List;
import java.util.Map;
import java.util.Set;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.RoundEnvironment;
import javax.annotation.processing.SupportedAnnotationTypes;
import javax.annotation.processing.SupportedSourceVersion;
import javax.lang.model.SourceVersion;
import javax.lang.model.element.AnnotationMirror;
import javax.lang.model.element.AnnotationValue;
import javax.lang.model.element.Element;
import javax.lang.model.element.ExecutableElement;
import javax.lang.model.element.TypeElement;
import javax.lang.model.util.ElementFilter;
import javax.tools.Diagnostic.Kind;
@SupportedAnnotationTypes( "ToBeTested" )
@SupportedSourceVersion( SourceVersion.RELEASE_6 )
public class MyAnnotationProcessor extends AbstractProcessor ...{
private void note( String msg ) ...{
processingEnv.getMessager().printMessage( Kind.NOTE, msg );
}
public boolean process( Set< ? extends TypeElement > annotations, RoundEnvironment roundEnv ) ...{
for( TypeElement te : annotations ) ...{
note( "annotation: " + te.toString() );
}
Set< ? extends Element > elements = roundEnv.getRootElements();
for( Element e : elements ) ...{
List< ? extends Element > enclosedElems = e.getEnclosedElements();
List< ? extends ExecutableElement > ees = ElementFilter.methodsIn( enclosedElems );
for( ExecutableElement ee : ees ) ...{
note( "Executable Element Name: " + ee.getSimpleName() );
List< ? extends AnnotationMirror > as = ee.getAnnotationMirrors();
note( " as: " + as );
for( AnnotationMirror am : as )...{
Map< ? extends ExecutableElement, ? extends AnnotationValue > map = am.getElementValues();
Set< ? extends ExecutableElement > ks = map.keySet();
for( ExecutableElement k : ks ) ...{
AnnotationValue av = map.get( k );
note("----"+ee.getSimpleName()+"."+k.getSimpleName()+"="+av.getValue());
}
}
}
}
return false;
}
}
public class Testing ...{
@ToBeTested(group="A")
public void m1()...{
}
@ToBeTested(group="B",owner="QQ")
public void m2()...{
}
}
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention( RetentionPolicy.RUNTIME )
@Target( ElementType.METHOD )
public @interface ToBeTested ...{
String owner() default "Chinajash";
String group();
}
效果如下:
7.SAX. SAX是The Streaming API for XML的缩写,是继DOM(Document Object Model)和SAX(Simple API for XML)之后的又一种处理xml的api,一种利用拉模式解析(pull-parsing)XML文档的API.SAX通过提供一种基于事件迭代器(Iterator)的API让程序员去控制xml文档解析过程,程序遍历这个事件迭代器去处理每一个解析事件,解析事件可以看做是程序拉出来的,也就是程序促使解析器产生一个解析事件然后处理该事件,之后又促使解析器产生下一个解析事件,如此循环直到碰到文档结束符;SAX也是基于事件处理xml文档,但却是用推模式解析,解析器解析完整个xml文档后,才产生解析事件,然后推给程序去处理这些事件;DOM采用的方式是将整个xml文档映射到一颗内存树,这样就可以很容易地得到父节点和子结点以及兄弟节点的数据,但如果文档很大,将会严重影响性能。
下面是个例子:
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLOutputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class SaxTest ...{
public static void main( String[] arg ) throws XMLStreamException, FileNotFoundException ...{
readXMLBySAX();
writeXMLBySAX();
}
public static void readXMLBySAX() throws XMLStreamException, FileNotFoundException ...{
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader reader = factory.createXMLEventReader( SaxTest.class.getResourceAsStream( "test.xml" ) );
XMLEvent event;
StringBuffer parsingResult = new StringBuffer();
while( reader.hasNext() ) ...{
event = reader.nextEvent();
if( event.isStartElement() ) ...{
StartElement se = event.asStartElement();
parsingResult.append( "<" );
parsingResult.append( se.getName() );
if( se.getName().getLocalPart().equals( "catalog" ) ) ...{
parsingResult.append( "id="" );
parsingResult.append( se.getAttributeByName( new QName( "id" ) ).getValue());
parsingResult.append( """ ) ;
}
parsingResult.append( ">" );
} else if( event.isCharacters() ) ...{
parsingResult.append( event.asCharacters().getData() );
} else if( event.isEndElement() ) ...{
parsingResult.append( "</" );
parsingResult.append( event.asEndElement().getName() );
parsingResult.append( ">" );
}
}
System.out.println( parsingResult );
}
public static void writeXMLBySAX() throws XMLStreamException, FileNotFoundException ...{
XMLOutputFactory factory = XMLOutputFactory.newInstance();
XMLStreamWriter writer = factory.createXMLStreamWriter( new FileOutputStream( "output.xml" ) );
writer.writeStartDocument();
writer.writeCharacters( " " );
writer.writeComment( "testing comment" );
writer.writeCharacters( " " );
writer.writeStartElement( "catalogs" );
writer.writeNamespace( "myNS", "http://blog.csdn.net/Chinajash" );
writer.writeAttribute( "owner", "sina" );
writer.writeCharacters( " " );
writer.writeStartElement("http://blog.csdn.net/Chinajash", "catalog");
writer.writeAttribute("id","007");
writer.writeCharacters("Apparel");
// 写入catalog元素的结束标签
writer.writeEndElement();
// 写入catalogs元素的结束标签
writer.writeEndElement();
// 结束 XML 文档
writer.writeEndDocument();
writer.close();
}
}
test.xml:
<?xml version="1.0" encoding="UTF-8"?>
<catalogs>
<catalog id="001">Book</catalog>
<catalog id="002">Video</catalog>
</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发布的类。
package hello;
import javax.jws.WebService;
import javax.xml.ws.Endpoint;
@WebService
public class CircleFunctions ...{
public double getArea( int radius ) ...{
return Math.PI * radius * radius;
}
public double getCircumference( int radius ) ...{
return Math.PI * radius * 2;
}
public static void main( String[] args ) ...{
Endpoint.publish( "http://localhost:8888/WebServiceExample/circlefunctions", new CircleFunctions());
}
}
处理的方法如下:
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.SAX. 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
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( "64398966@qq.com" );
}
});
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 .
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.InetSocketAddress;
import com.sun.net.httpserver.HttpExchange;
import com.sun.net.httpserver.HttpHandler;
import com.sun.net.httpserver.HttpServer;
public class HttpServerAPITest ...{
private static int count = 0;
public static void main( String[] args ) ...{
try ...{
HttpServer hs = HttpServer.create( new InetSocketAddress( 8888 ), 0 );
hs.createContext( "/", new MyHandler() );
hs.createContext( "/java", new MyHandler() );
hs.setExecutor( null );
hs.start();
System.out.println( "---begin---" );
System.out.println( "Listening on " + hs.getAddress() );
} catch( IOException ioe ) ...{
ioe.printStackTrace();
}
}
static class MyHandler implements HttpHandler ...{
public void handle( HttpExchange he ) throws IOException ...{
System.out.println( "Request " + count++ );
System.out.println( he.getHttpContext().getPath() );
InputStream is = he.getRequestBody();
String response = "<font color='blue'>Happy Spring Festerval</font>";
he.sendResponseHeaders( 200, response.length() );
OutputStream os = he.getResponseBody();
os.write( response.getBytes() );
os.close();
}
}
}
效果如图:
5.对脚本语言的支持如: ruby, groovy, javascript.
代码如下:
import java.io.FileReader;
import javax.script.Invocable;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
public class ScriptTest ...{
public static void main( String[] args ) ...{
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName( "ECMAScript" );
try ...{
engine.eval( new FileReader( "C:\test.js" ) );
Invocable invocableEngine = (Invocable)engine;
Object ret = invocableEngine.invokeFunction( "test", null );
System.out.println( "The result is :" + (Double)ret );
} catch( Exception e ) ...{
e.printStackTrace();
}
}
}
test.js如下:
function test()...{
return Math.round( 11.2 );
}
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来标识测试期间需要执行的测试方法,如下所示:
@TestMethod
public void testCheckName()...{
//do something here
}
这时我们就可以用JSR 269提供的API来处理测试类,根据Annotation提取出需要执行的测试方法.
再举个例子: 下面我用代码演示如何来用JSR 269提供的API来处理Annotations和读取Java源文件的元数据(metadata)
import java.util.List;
import java.util.Map;
import java.util.Set;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.RoundEnvironment;
import javax.annotation.processing.SupportedAnnotationTypes;
import javax.annotation.processing.SupportedSourceVersion;
import javax.lang.model.SourceVersion;
import javax.lang.model.element.AnnotationMirror;
import javax.lang.model.element.AnnotationValue;
import javax.lang.model.element.Element;
import javax.lang.model.element.ExecutableElement;
import javax.lang.model.element.TypeElement;
import javax.lang.model.util.ElementFilter;
import javax.tools.Diagnostic.Kind;
@SupportedAnnotationTypes( "ToBeTested" )
@SupportedSourceVersion( SourceVersion.RELEASE_6 )
public class MyAnnotationProcessor extends AbstractProcessor ...{
private void note( String msg ) ...{
processingEnv.getMessager().printMessage( Kind.NOTE, msg );
}
public boolean process( Set< ? extends TypeElement > annotations, RoundEnvironment roundEnv ) ...{
for( TypeElement te : annotations ) ...{
note( "annotation: " + te.toString() );
}
Set< ? extends Element > elements = roundEnv.getRootElements();
for( Element e : elements ) ...{
List< ? extends Element > enclosedElems = e.getEnclosedElements();
List< ? extends ExecutableElement > ees = ElementFilter.methodsIn( enclosedElems );
for( ExecutableElement ee : ees ) ...{
note( "Executable Element Name: " + ee.getSimpleName() );
List< ? extends AnnotationMirror > as = ee.getAnnotationMirrors();
note( " as: " + as );
for( AnnotationMirror am : as )...{
Map< ? extends ExecutableElement, ? extends AnnotationValue > map = am.getElementValues();
Set< ? extends ExecutableElement > ks = map.keySet();
for( ExecutableElement k : ks ) ...{
AnnotationValue av = map.get( k );
note("----"+ee.getSimpleName()+"."+k.getSimpleName()+"="+av.getValue());
}
}
}
}
return false;
}
}
public class Testing ...{
@ToBeTested(group="A")
public void m1()...{
}
@ToBeTested(group="B",owner="QQ")
public void m2()...{
}
}
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
@Retention( RetentionPolicy.RUNTIME )
@Target( ElementType.METHOD )
public @interface ToBeTested ...{
String owner() default "Chinajash";
String group();
}
效果如下:
7.SAX. SAX是The Streaming API for XML的缩写,是继DOM(Document Object Model)和SAX(Simple API for XML)之后的又一种处理xml的api,一种利用拉模式解析(pull-parsing)XML文档的API.SAX通过提供一种基于事件迭代器(Iterator)的API让程序员去控制xml文档解析过程,程序遍历这个事件迭代器去处理每一个解析事件,解析事件可以看做是程序拉出来的,也就是程序促使解析器产生一个解析事件然后处理该事件,之后又促使解析器产生下一个解析事件,如此循环直到碰到文档结束符;SAX也是基于事件处理xml文档,但却是用推模式解析,解析器解析完整个xml文档后,才产生解析事件,然后推给程序去处理这些事件;DOM采用的方式是将整个xml文档映射到一颗内存树,这样就可以很容易地得到父节点和子结点以及兄弟节点的数据,但如果文档很大,将会严重影响性能。
下面是个例子:
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLOutputFactory;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamWriter;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;
public class SaxTest ...{
public static void main( String[] arg ) throws XMLStreamException, FileNotFoundException ...{
readXMLBySAX();
writeXMLBySAX();
}
public static void readXMLBySAX() throws XMLStreamException, FileNotFoundException ...{
XMLInputFactory factory = XMLInputFactory.newInstance();
XMLEventReader reader = factory.createXMLEventReader( SaxTest.class.getResourceAsStream( "test.xml" ) );
XMLEvent event;
StringBuffer parsingResult = new StringBuffer();
while( reader.hasNext() ) ...{
event = reader.nextEvent();
if( event.isStartElement() ) ...{
StartElement se = event.asStartElement();
parsingResult.append( "<" );
parsingResult.append( se.getName() );
if( se.getName().getLocalPart().equals( "catalog" ) ) ...{
parsingResult.append( "id="" );
parsingResult.append( se.getAttributeByName( new QName( "id" ) ).getValue());
parsingResult.append( """ ) ;
}
parsingResult.append( ">" );
} else if( event.isCharacters() ) ...{
parsingResult.append( event.asCharacters().getData() );
} else if( event.isEndElement() ) ...{
parsingResult.append( "</" );
parsingResult.append( event.asEndElement().getName() );
parsingResult.append( ">" );
}
}
System.out.println( parsingResult );
}
public static void writeXMLBySAX() throws XMLStreamException, FileNotFoundException ...{
XMLOutputFactory factory = XMLOutputFactory.newInstance();
XMLStreamWriter writer = factory.createXMLStreamWriter( new FileOutputStream( "output.xml" ) );
writer.writeStartDocument();
writer.writeCharacters( " " );
writer.writeComment( "testing comment" );
writer.writeCharacters( " " );
writer.writeStartElement( "catalogs" );
writer.writeNamespace( "myNS", "http://blog.csdn.net/Chinajash" );
writer.writeAttribute( "owner", "sina" );
writer.writeCharacters( " " );
writer.writeStartElement("http://blog.csdn.net/Chinajash", "catalog");
writer.writeAttribute("id","007");
writer.writeCharacters("Apparel");
// 写入catalog元素的结束标签
writer.writeEndElement();
// 写入catalogs元素的结束标签
writer.writeEndElement();
// 结束 XML 文档
writer.writeEndDocument();
writer.close();
}
}
test.xml:
<?xml version="1.0" encoding="UTF-8"?>
<catalogs>
<catalog id="001">Book</catalog>
<catalog id="002">Video</catalog>
</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发布的类。
package hello;
import javax.jws.WebService;
import javax.xml.ws.Endpoint;
@WebService
public class CircleFunctions ...{
public double getArea( int radius ) ...{
return Math.PI * radius * radius;
}
public double getCircumference( int radius ) ...{
return Math.PI * radius * 2;
}
public static void main( String[] args ) ...{
Endpoint.publish( "http://localhost:8888/WebServiceExample/circlefunctions", new CircleFunctions());
}
}
处理的方法如下:
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.SAX. 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
发表评论
-
淘宝Java中间件之路
2011-09-19 09:08 2356淘宝Java中间件之路 it168 -
淘宝技术嘉年华 Java@Taobao PPT
2011-07-11 12:02 2808淘宝技术嘉年华上的Java@Taobao的PPT下载 ... -
Java HashMap的并发问题
2011-02-22 09:42 4757使用Java的同学应该都是知道HashMap是线程不安全的,不 ... -
Java Basic Diagnosis Tool
2011-02-22 08:58 1528之前遇到过几次Java占用CPU过多的问题,去定位问题的办 ... -
通过编程获取Whois的信息
2011-02-04 10:34 2835近期帮助同事在处理从纯真网络上拿到的IP信息,确定这些IP所在 ... -
JavaOne 2010 北京 Session的评价
2010-12-18 09:46 1222在基于Java技术的Web服务 ... -
JavaOne 2010 北京 我的Session选择
2010-12-18 09:46 9662010 JavaOne 北京,我的Session选择 ... -
北京参加 iDataForum总结
2010-12-18 09:45 1195感谢淘宝DBA的邀请,参加了12月12号在北京的iD ... -
Java中Tree的序列化
2009-06-19 09:02 2624工作中,遇到了在Java里 ... -
DBCP
2008-05-01 18:33 2406DBCP是apache下面的一个开源的数据库连接 ... -
Eclipse下XmlBuddy和jpdl-gpd的冲突
2008-05-01 18:15 1579近日想学习一下jBPM,看到有一个插件可以图形化的进行流程的编 ...
相关推荐
**JDK 6.0 新特性详解** JDK 6.0,全称为Java Development Kit 6.0,是Oracle公司发布的Java平台标准版(Java SE)的重要版本,它引入了一系列增强功能,提升了开发效率、性能和兼容性。以下是这个版本的一些核心新...
JDK6.0的主要特性:** - **增强的动态代理:** JDK 6.0引入了改进的动态代理机制,允许开发者创建能够处理多个接口的代理类,提高了代码的灵活性和可维护性。 - **Swing组件的增强:** Swing库在JDK 6.0中得到了...
这一版本引入了许多新特性和改进,包括: 1. **改进的Swing组件**:JDK 6.0对Swing UI库进行了增强,提供了更好的外观和感觉,支持更多的操作系统主题,并且增强了性能。 2. **JavaScript交互**:通过Java Web ...
这个主题涵盖了Java语言的基础特性、语法规范以及开发环境的配置和使用,同时也深入到JDK6.0的核心源代码层面,为开发者提供了全面理解Java平台的窗口。 在Java语言特点方面,JDK6.0引入了许多增强,如改进的Swing...
这份"jdk6.0中文文档"是针对JDK 6.0的官方帮助文档,它提供详尽的API参考、教程和指导,对于理解和使用JDK 6.0至关重要。 **一、JDK 6.0的主要特性** 1. **增强的Swing组件**:JDK 6.0在Swing UI库中进行了大量...
JDK 6.0是Oracle公司于2006年发布的一个重要版本,它是Java SE(Java Standard Edition)的一部分,提供了许多新特性和改进。这个压缩包中包含的"java学习笔记JDK6课件和课本代码"是学习JDK 6.0的重要参考资料,可以...
在JDK 6.0中,还引入了一些其他重要特性,例如改进的Swing GUI组件,包括更好的外观和感觉,以及对桌面应用的支持。新的I/O流API扩展了NIO(非阻塞I/O),使得处理大量并发I/O操作更加高效。此外,改进的异常处理...
JDK 6.0是Oracle公司发布的一个重要版本,它在JDK 5.0的基础上增加了很多新特性,提升了性能,并对API进行了大量的改进和完善。 JDK 6.0 API官方中文版CHM文件是一个非常实用的开发参考文档,它是以Windows帮助文件...
**一、JDK 6.0新特性** 1. **改进的Swing组件**:JDK 6.0对Swing UI库进行了优化,增强了组件的性能和外观,如添加了JTabbedPane的分页动画效果,使得图形界面更加友好。 2. **动态代理**:Java 6引入了java.lang....
这个版本的JDK在当时引入了多项新特性和改进,旨在提升开发效率和性能。本文将深入探讨JDK 6.0的关键知识点。 一、增强的编译器性能 JDK 6.0中的Java HotSpot虚拟机(JVM)进行了优化,使得编译器性能显著提升。这...
JDK 6.0 API 文档是Java开发者的重要...总之,JDK 6.0 API 文档是每一位Java开发者不可或缺的参考资料,它详细阐述了Java 6的各个方面,涵盖了从基本类型到复杂特性的所有内容,帮助开发者深入理解并有效利用Java平台。
JDK(Java Development Kit)是Oracle公司提供的用于开发和运行Java应用程序的工具包,而JDK 6.0是其在2006年发布的一个重要版本,它在Java SE(标准版)平台上带来了许多新特性、改进和优化。这个版本的发布对于...
1. **增强的编译器(Java Compiler, javac)**:JDK 6.0的javac编译器进行了优化,提高了编译速度,并支持了一些新的语法特性,如泛型的更好类型推断(Type Inference for Generic Instance Creation)。 2. **动态...
通过"jdk6.0-02.zip"压缩包中的CHM文档,开发者可以深入学习这些特性和API的使用,理解JDK 6.0在性能、可维护性和开发便利性上的改进。无论你是初学者还是经验丰富的开发者,这份文档都是掌握和利用JDK 6.0的关键...
首先,JDK6.0(也称为Java SE 6)引入了许多新特性和性能优化,以提升开发效率和程序运行效能。例如,它加强了Java语言本身,添加了诸如try-with-resources语句、泛型的改进、枚举的for-each循环等新特性,这些都...
Java JDK 6.0是Oracle公司发布的一个重要版本,提供了许多新的特性和改进,对于学习Java的初学者和专业开发者来说都具有重要意义。 **入门准备** 在开始Java之旅前,首先需要了解计算机的基本知识,包括操作系统...
`JDK6.0.chm.bat` 可能是一个批处理文件,它的目的是为了方便用户打开CHM文件。在Windows操作系统中,批处理文件是一系列命令的集合,可以一次性执行多个操作。在这个场景下,用户只需双击该批处理文件,就可以启动...
同时,对JDK 6.0特性如`TimeUnit`、`ExecutorService`的了解和运用,也是提高代码效率的关键。压缩包中的`src`文件夹可能包含了源代码,通过阅读和分析这些代码,可以进一步学习和理解上述技术的应用。
《Java JDK6.0 API参考手册》是Java开发工程师的重要参考资料,它详尽地阐述了JDK6.0版本中的各种API(Application Programming Interface)功能和用法。这份手册以中文呈现,旨在帮助国内开发者更好地理解和应用...