java基础--输入与输出重定向(in,out,err的使用)


要点:

System.out与err是输出流,默认是输出到console。

system.in是输出流,默认是接收来自键盘的数据

实现要求:从键盘和文件readme.txt中读取数据,输出到console,输出到log.txt。

 1、从readme.txt读取数据,输出到控制台和log.txt

import java.io.BufferedInputStream; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.io.PrintStream; import java.util.Scanner;

public class in_out_err {  public static void main(String[] args) throws IOException{  

//从readme.txt读取数据,输出到console和log.txt       BufferedInputStream in=new BufferedInputStream(new FileInputStream("c:\\readme.txt")); //创建缓冲输入流   System.setIn(in);   BufferedReader stdin=new BufferedReader(new InputStreamReader(System.in));//将System.in封装为BufferReader,便于readline   String s;   while((s=stdin.readLine())!=null){    System.out.println(s);    //输出到log.txt    PrintStream out=System.out;//保存原输出流    PrintStream log=new PrintStream("c:\\log.txt"); //创建文件输出流    System.setOut(log); //设置使用新的输出流    System.out.println("以下信息应该出现在日志文件中:"+s);    System.setOut(out); //恢复原有输出流    System.out.println("程序运行完毕,请查看日志文件");   } }}

 

运行结果:1.1 控制台截图:

                     2.2 log.txt内容截图:  

 

 

2、从键盘读数据,输出到console和log.txt。

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.util.Scanner;


public class in_out_err {
	public static void main(String[] args) throws IOException{
		
		//从键盘读取数据,输出到console上和log.txt
		Scanner scanner=new Scanner(System.in); //创建输入流扫描器		
System.out.println("请输入你的身份证号:");
		String id=scanner.nextLine();
		  	//输出到console上
		System.out.println(id);
			//输出到log.txt
		PrintStream out=System.out;//保存原输出流
		PrintStream log=new PrintStream("c:\\log.txt"); //创建文件输出流
		System.setOut(log);	//设置使用新的输出流
		System.out.println("以下信息应该出现在日志文件中"+id);
		System.setOut(out);	//恢复原有输出流 也可以用log.close();实现
		System.out.println("程序运行完毕,请查看日志文件");
		
	}
}

运行结果:

  2.1 console截图:

2.2 log.txt的内容:


F6执行当前行,F8运行到下一断点,如果不想debug的话,一直按F8就可以了。

*******************************************************************华丽分割线**************************************************************************************

System.out和System.err已经被封装为PrintStream对象,可以直接使用。而System.in是一个未经封装InputStream,所以要想利用System.in读取文件前必须要对齐进行封装,一般封装为BufferedReader(便于readline()),这就要求利用InputStreamReader将System.in转换为Reader。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值