Java System 类详解 - in, out, err

几乎所有的都用过这个System类吧,因为大家学习的第一个语句大概就是

Java代码   收藏代码
  1. package jdk.lang;  
  2.   
  3. public class SystemInspection {  
  4.     public static void main(String[] args) throws Exception {  
  5.         System.out.println(“Hello World”);  
  6.     }  
  7. }  


本文将一一详解这个类的标准输入(in),输出(out)和错误流(err)使用和原理。先看一个更复杂的例子:

Java代码   收藏代码
  1. package jdk.lang;  
  2.   
  3. public class SystemIOE {  
  4.     public static void main(String[] args) throws Exception {  
  5.         System.out.println("Hello Out");  
  6.         System.err.println("Hello Error");  
  7.         byte[] b = new byte[1024];  
  8.         int count = System.in.read(b);  
  9.         System.out.println(new String(b, 0, count));  
  10.     }  
  11. }  



在eclipse上运行,输出:

Hello Out
Hello Error
Hello In 
Hello In

分析:

其实out, in 和 err是它的静态属性:

Java代码   收藏代码
  1. public final static InputStream in = nullInputStream();  
  2. public final static PrintStream out = nullPrintStream();  
  3. public final static PrintStream err = nullPrintStream();  



他们其实是在private static void initializeSystemClass()中初始化的:

Java代码   收藏代码
  1. FileInputStream fdIn = new FileInputStream(FileDescriptor.in);  
  2.     FileOutputStream fdOut = new FileOutputStream(FileDescriptor.out);  
  3.     FileOutputStream fdErr = new FileOutputStream(FileDescriptor.err);  
  4.     setIn0(new BufferedInputStream(fdIn));  
  5.     setOut0(new PrintStream(new BufferedOutputStream(fdOut, 128), true));  
  6.     setErr0(new PrintStream(new BufferedOutputStream(fdErr, 128), true));  



FileDescriptor.out,FileDescriptor.in和FileDescriptor.err其实是

Java代码   收藏代码
  1. public static final FileDescriptor in = standardStream(0);  
  2. public static final FileDescriptor out = standardStream(1);  
  3. public static final FileDescriptor err = standardStream(2);  


再往下就是native的调用了。
同时System类还提供方法让你设置in,out和err,这样你就可以实现自己的日志系统了。运行下面的代码:

Java代码   收藏代码
  1. package jdk.lang;  
  2.   
  3. import java.io.BufferedInputStream;  
  4. import java.io.File;  
  5. import java.io.FileInputStream;  
  6. import java.io.FileNotFoundException;  
  7. import java.io.FileOutputStream;  
  8. import java.io.IOException;  
  9. import java.io.InputStream;  
  10. import java.io.PrintStream;  
  11.   
  12. public class SystemIOE {  
  13.     public static void main(String[] args) throws Exception {  
  14.         redirect();  
  15.         helloIO();  
  16.     }  
  17.   
  18.     private static void helloIO() throws IOException {  
  19.         System.out.println("Hello Out");  
  20.         System.err.println("Hello Error");  
  21.         byte[] b = new byte[1024];  
  22.         int count = System.in.read(b);  
  23.         System.out.println(new String(b, 0, count));  
  24.     }  
  25.   
  26.     public static void redirect() throws FileNotFoundException {  
  27.         InputStream in = new BufferedInputStream(new FileInputStream(new File(  
  28.                 "c:/in.txt")));  
  29.         System.setIn(in);  
  30.         PrintStream out = new PrintStream(new FileOutputStream(new File(  
  31.                 "c:/out.log")));  
  32.         System.setOut(out);  
  33.         PrintStream err = new PrintStream(new FileOutputStream(new File(  
  34.                 "c:/err.log")));  
  35.         System.setErr(err);  
  36.     }  
  37. }  

     

    转自:http://jackycheng2007.iteye.com/blog/1473625


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值