用户操作
[即时聊天] [发私信] [加为好友]
曾巧ID:numenZQ
42205次访问,排名2821,好友0人,关注者0人。
numenZQ的文章
原创 29 篇
翻译 16 篇
转载 2 篇
评论 16 篇
最近评论
xh:不推荐修改web.xml,设置java_options更好
numenZQ:补充说明一点,使用java.util.zip包时,是以UTF-8编码格式读取的文件名,因此在中文windows操作系统(Windows操作系统默认字符集为:GBK)中使用时会导致文件名解析错误,因此需要使用org.apache.tools.zip.ZipEntry和 org.apache.tools.zip.ZipOutputStream类来解决这一问题。
numenZQ:这个是需要明确知道字符串的成分,该方法只是为了满足读取不同字符集相应字符串,还是以“多哈亚运会”为例:如果字符集为GBK,截取前6个字节,结果为:“多哈亚”;当字符集为UTF-8时,截取前6个字节,结果则为:“多哈”,这是因为GBK是双字节编码,而UTF-8是三字节变长编码,如果不分字符集来读取对应长度的字串,则会出现字串内容与预期不符,长度错误等问题。
lyazure:仔细看了你的代码,作用是从一个字符串中获取指定字节数的字符,不知道你要这么做的最终目的是用来做什么。除非明确知道字符串的成分,否则这种做法很难做到完美,比如你的代码中,假如出现要从“多哈亚运会”这样的字符串中截取7个字节,最终会截得3个字符。
Alexandre:ab8e44bc75204d49bf0c9fe68a2b2176 matura foto amatoriale
收藏
    相册
    存档
    软件项目交易
    订阅我的博客
    XML聚合  FeedSky
    订阅到鲜果
    订阅到Google
    订阅到抓虾
    订阅到BlogLines
    订阅到Yahoo
    订阅到GouGou
    订阅到飞鸽
    订阅到Rojo
    订阅到newsgator
    订阅到netvibes

    翻译 捕捉未捕获的异常收藏

    新一篇: 在桌面应用中使用JAVA DB | 旧一篇: JSP轻松入门(二)

    原文地址:http://java.sun.com/developer/JDCTechTips/2006/tt0211.html#2

    日期:2006-02-11

     

    2004316的技术技巧Best Practices in Exception Handling讲述了几个处理异常的最好实践。在该技巧中,你将学习另外一个处理异常的方法。我们是通过J2SE 5.0 新增的UncaughtExceptionHandler接口来处理。

           UncaughtExceptionHandler名字意味着处理未捕获的异常。更明确的说,它处理未捕获的运行时异常。Java编译器要求处理所有非运行时异常,否则程序不能编译通过。这里“处理”的是方法里throws子句声明的异常或在try-catch块里的catch子句的异常。

           在下面的示例中,让我们关注两个异常:FileNotFoundExceptionArithmeticException。如果使用一个不正确的StringFile参数值来构造FileReader时,将会抛出FileNotFoundException异常。当你调用这些构造函数时,编译器要求你处理每一个可能抛出异常的子句:

     

    FileReader input;

       String filename = ...;

       try {

         input = new FileReader(filename);

       } catch (FileNotFoundException e) {

         processMissingFile(filename, e);

       }

          

    我们再来比较一下,ArithmeticException是一个运行时异常。Java编程语言规范(对于编译器而言)不要求处理运行时异常。因此在下面的循环中,从100都会被100除,而在最后一次循环中将抛出ArithmeticException异常:

     

    for (int i=10; i >= 0; i--) {

         int div = 100 / i;

       }

     

       Exception in thread "main" java.lang.ArithmeticException: /

       by zero

            at Test.main(Test.java:4)

          

    输出堆栈信息显示出缺省未捕获的异常内容。通常说来,这样的缺省行为已经足够了,不过有时也不行。设想你想在弹出式窗口输出堆栈信息,来替代在系统控制台输出该信息。如果你自己设置一个缺省的未捕获异常处理,你就可以得到这样的效果。

           这里有三个最新的处理未捕获异常的方法。第一,你可以调用ThreadsetUncaughtExceptionHandler()方法。这个方法允许你在特殊的线程里定制行为。第二,你可以定义你自己的ThreadGroup并改变行为使每个线程都从这个组中创建并重写它们的uncaughtException()方法。第三,你可以设置缺省行为让所有线程调用Thread的静态方法setDefaultUncaughtExceptionHandler()

           ThreadsetUncaughtExceptionHandler()setDefaultUncaughtExceptionHandler()方法都需要实现UncaughtExceptionHandler接口作为参数。该接口是Thread类的内部接口,因此它的全名是Thread.UncaughtExceptionHandler。该接口的唯一方法是:

     

    void uncaughtException(Thread t, Throwable e)

     

    当你实现了uncaughtException方法或实现了该接口或重写ThreadGroup的方法,你都可以定制其行为。在下面的示例中,我们实现了UncaughtExceptionHandler,无论运行时异常何时发生,堆栈信息都会显示在窗口的文本区域里。你可以在两个异常间关闭窗口。当下次异常发生时,窗口会再次出现在其他窗口之前。

     

    import java.awt.*;

       import java.io.*;

       import javax.swing.*;

     

       public class StackWindow extends JFrame

           implements Thread.UncaughtExceptionHandler {

     

         private JTextArea textArea;

     

         public StackWindow(

          String title, final int width, final int height) {

           super(title);

           setSize(width, height);

           textArea = new JTextArea();

           JScrollPane pane = new JScrollPane(textArea);

           textArea.setEditable(false);

           getContentPane().add(pane);

         }

     

         public void uncaughtException(Thread t, Throwable e) {

           addStackInfo(e);

         }

     

         public void addStackInfo(final Throwable t) {

           EventQueue.invokeLater(new Runnable() {

             public void run() {

               // Bring window to foreground

               setVisible(true);

               toFront();

               // Convert stack dump to string

               StringWriter sw = new StringWriter();

               PrintWriter out = new PrintWriter(sw);

               t.printStackTrace(out);

               // Add string to end of text area

               textArea.append(sw.toString());

            }

         });

       }

      }

     

    要测试这个处理,你需要一个程序来设置这个处理并抛出一些运行时异常。在下面的程序中,DumpTeat将会这样做。为了简单,DumpTest仅仅产生两个异常。如果要抛出更多的异常,你可以自由的在程序里添加更多的错误代码。程序在第一个异常显示后会暂停,你可以在异常间关闭异常堆栈窗口。

     

    import java.io.*;

     

       public class DumpTest {

        public static void main(final String args[])

         throws Exception {

           Thread.UncaughtExceptionHandler handler =

             new StackWindow("Show Exception Stack", 400, 200);

           Thread.setDefaultUncaughtExceptionHandler(handler);

           new Thread() {

             public void run() {

               System.out.println(1 / 0);

             }

           }.start();

           BufferedReader br =

             new BufferedReader(new InputStreamReader(System.in));

           System.out.print("Press Enter for next exception");

           br.readLine();

           new Thread() {

             public void run() {

               System.out.println(args[0]);

             }

           }.start();

           System.out.print("Press Enter to end");

           br.readLine();

           System.exit(0);

         }

       }

     

    编译StackWindowDumpTest。当你运行DumpTest时,在控制台里会看见下面的内容:

    > java DumpTest

       Press Enter for next exception

    你将看见堆栈信息显示在窗口里的文本区域里。

    按下Enter,在控制台里回看见下面的内容:

    Press Enter to end

    你可以在窗口的文本区里看见另一个堆栈信息。

    虽然你可以认为这些是处理未捕获的异常的所有方法,其实还有更多的方法。模式对话框要求有它自己的事件线程,因为它自己非捕获处理。系统属性sun.awt.exception.handler覆盖了所有容器,但不是好的文档。RFE(增强型请求)提交了可扩展的属性到正式的API中。

    Best Practices in Exception Handling外,20025月的技巧文章StackTraceElements也是一篇重要的参考。也可以看The Java TutorialHandling Errors Using Exception课程。 

    发表于 @ 2006年07月01日 15:54:00|评论(loading...)|编辑

    新一篇: 在桌面应用中使用JAVA DB | 旧一篇: JSP轻松入门(二)

    评论:没有评论。

    发表评论  


    登录
    Csdn Blog version 3.1a
    Copyright © numenzq