java的输出流与输入流的讲解

时间:2023-02-24 21:28:32

package test;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

public class TestIo {

 public static void main(String[] args) {
  //创建标准输入流的对象
  InputStream is = System.in;
  //创建标准输出流的对象
  OutputStream os = System.out;  
  try {
   //创建指定长度的缓冲区
   byte[] buffer = new byte[10];
   //定义结束条件,检测实际的读取字节长度
   int len = 0;
   //len接收输入流is向Buffer实际读入的字节长度   
   len = is.read(buffer, 0, 4);
   //循环(无所谓,在这里呈现的是可以一直在控制台测试的结果)
   while (len != -1) {//如果输入流不是控制台接收的,是从资源读取时,当读取完资源时read返回-1,即结束循环
    //显示实际的读取字节长度
    System.out.println("缓存字符长度:"+len);
    //os接收由Buffer中向外写入的信息,并直接显示在控制台
    os.write(buffer, 0, 4);
    System.out.println("---------------");
   }
  } catch (IOException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
 }
}


/*
  测试结果呈现:
  从键盘输入: 12345
 
 
 控制台输出结果:
 
  缓存字符长度:4
  1234---------------
  缓存字符长度:3
  5
  4---------------
  
  
 从呈现的结果并结合API分析得到:
  缓冲区域内的数据一旦写入就会一直存在,等待下一次读入数据的覆盖;
  所以,当第二次的读入操作长度没有达到指定缓存区长度时,
  缓存区内会有上一次数据的残留,
  这就是最后4输出的原因;
  注意:在UTF-8编码下,回车 \r ,换行  \n  各占一个字节,当在控制台进行回车操作时会向输入流中写入这两个编码
 */