【CODE】重定向输出流实现程序日志

1.代码

package Test;
 
import java.io.FileNotFoundException;
import java.io.PrintStream;
import java.net.StandardSocketOptions;
 
public class Test01 {
 
	public static void main(String[] args) {
		try {
			//保存原输出流
			PrintStream out = System.out;
			//创建文件输出流
			PrintStream ps=new PrintStream("./log.txt");
			//设置使用新的输出流
			System.setOut(ps);
			//定义整型变量
			int age=18;
			System.out.println("年龄变量成功定义,初始值为18");
			//定义字符串变量
			String sex="女";
			System.out.println("性别变量成功定义,初始值为女");
			String info="这是个"+sex+"孩子,应该有"+age+"岁了。";
			System.out.println("整合两个变量为info字符串变量,其结果是:"+info);
			//恢复原有的输出流
			System.setOut(out);
			System.out.println("程序运行完毕,请查看日志文件。");
		} catch (FileNotFoundException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

技术要点:

  • setOut()方法
    该方法用于重新分配System类的标准输出流

  • setErr()方法
    该方法将重新分配System类的标准错误输出流

  • setIn()方法
    该方法将重新设置System类的标准输入流

2.效果

【CODE】重定向输出流实现程序日志
【CODE】重定向输出流实现程序日志