zoukankan      html  css  js  c++  java
  • 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


  • 相关阅读:
    2-红帽RHEL 7起步
    1-了解开源共享精神
    5.pip安装时使用国内源,加快下载速度
    4. python-运算符(另类语法)
    海燕python学习目录,特别棒!
    1Python学习CentOS 7 Linux环境搭建
    2python脚本在window编辑后linux不能执行的问题
    3Python脚本在linux环境下头文件解释
    5G 频谱 新技术
    python -实现单例模式五种方法
  • 原文地址:https://www.cnblogs.com/hnrainll/p/2735895.html
Copyright © 2011-2022 走看看