黑马程序员技术交流社区

标题: IO流将异常信息写入文件报错!求指教! [打印本页]

作者: huoxy    时间: 2014-11-4 20:51
标题: IO流将异常信息写入文件报错!求指教!
在看毕老师基础视频Day19的将异常信息通过IO流写入日志文件时,编写代码如下,但报错了,将最后一个catch块内的异常改为Exception可以编译通过,为什么不能用IOException???请各位大侠帮忙看一下!谢谢!
  1. /*
  2. 需求:直接将异常信息打印到控制台不便处理,
  3.           建议将异常信息打印到文件里!并将异常日期打印!
  4. */
  5. import java.io.*;
  6. import java.util.*;
  7. import java.text.*;

  8. class ExceptionInfo
  9. {
  10.         public static void main(String[] args)
  11.         {
  12.                 try
  13.                 {
  14.                         int[] arr = new int[2];
  15.                         System.out.println(arr[3]);
  16.                 }
  17.                 catch (Exception e)
  18.                 {
  19.                         PrintStream ps = null;
  20.                         try
  21.                         {
  22.                                 Date d = new Date();
  23.                                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  24.                                 String s = sdf.format(d);

  25.                                 ps = new PrintStream("Exception.log");
  26.                                 ps.println(s);
  27.                                 System.setOut(ps);
  28.                                
  29.                                 //打印到指定流
  30.                             e.printStackTrace(System.out);
  31.                         }
  32.                         catch (IOException ex)
  33.                         {
  34.                                 throw new RuntimeException("日志文件创建失败!");
  35.                         }
  36.                         finally
  37.                         {
  38.                                 try
  39.                                 {
  40.                                         if(ps!=null)
  41.                                                 ps.close();
  42.                                 }
  43.                                 catch (IOException exc)
  44.                                 {
  45.                                         throw new RuntimeException("关闭流对象失败!");
  46.                                 }
  47.                         }
  48.                        
  49.                 }
  50.         }
  51. }
复制代码



Error.JPG (29.43 KB, 下载次数: 9)

Error.JPG

作者: 李天富    时间: 2014-11-4 22:26
PrintStream 永远不会抛出 IOException,API中原话。

作者: huoxy    时间: 2014-11-5 09:11
李天富 发表于 2014-11-4 22:26
PrintStream 永远不会抛出 IOException,API中原话。

谢谢解答。 再问一下:第34行抛出IOException也不准确?我看了一下相对应的try块里没有抛出IOException的方法,为什么可以编译通过而且运行正常?
作者: 李天富    时间: 2014-11-5 13:36
huoxy 发表于 2014-11-5 09:11
谢谢解答。 再问一下:第34行抛出IOException也不准确?我看了一下相对应的try块里没有抛出IOException的 ...

我的理解是在使用PrintStream的功能时不会出现IOException,但是在创建PrintStream对象时依然可能抛出FileNotFoundException。





欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2