java io流初入门

FileInputStream/FileOutputStream,FileReader/FileWriter.

这两类io,操作文件流,前一个是操作字节流,后一个操作字符流。
这几个流的对象使用之后,最好在final模块中加上close更加安全。

Throws IOException:告知方法内部要抛出异常的一种声明,调用时可以用try{}catch{}方法体进行异常捕获。
E。printStackTrafce():命令打印异常信息在程序中出错的位置和原因。

附上代码:
package io;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;

public class javaio {
public static void FileInputStreamTest() throws IOException {
FileInputStream fis = new FileInputStream(“text.rtf”);
byte[] buf = new byte[1024];
int hasRead = 0;

     //read()返回的是单个字节数据(字节数据可以直接专程int类型),但是read(buf)返回的是读取到的字节数,真正的数据保存在buf中
     while ((hasRead = fis.read(buf)) > 0) {
         //每次最多将1024个字节转换成字符串,这里tmp2.txt中的字符小于1024,所以一次就读完了
         //循环次数 = 文件字符数 除以 buf长度
         System.out.println(new String(buf, 0 ,hasRead));
         /*
          * 将字节强制转换成字符后逐个输出,能实现和上面一样的效果。但是如果源文件是中文的话可能会乱码
          
         for (byte b : buf)    {
             char ch = (char)b;
             if (ch != '\r')
             System.out.print(ch);
         }
         */
     }
     //在finally块里close更安全
     fis.close();
 }
 
 public static void FileReaderTest() throws IOException {
     
     try (
             // 在try() 中打开的文件, JVM会自动关闭
             FileReader fr = new FileReader("text.rtf")) {
         char[] buf = new char[32];
         int hasRead = 0;
         // 每个char都占两个字节,每个字符或者汉字都是占2个字节,因此无论buf长度为多少,总是能读取中文字符长度的整数倍,不会乱码
         while ((hasRead = fr.read(buf)) > 0) {
             // 如果buf的长度大于文件每行的长度,就可以完整输出每行,否则会断行。
             // 循环次数 = 文件字符数 除以 buf长度
             System.out.println(new String(buf, 0, hasRead));
             // 跟上面效果一样
             // System.out.println(buf);
         }         } catch (IOException ex) {
         ex.printStackTrace();
     }
 }
 
 public static void FileOutputStreamTest() throws FileNotFoundException, IOException {
     try (    
             //在try()中打开文件会在结尾自动关闭
             FileInputStream fis = new FileInputStream("text.rtf");
             FileOutputStream fos = new FileOutputStream("text.rtf");
             ) {
         byte[] buf = new byte[4];
         int hasRead = 0;
         while ((hasRead = fis.read(buf)) > 0) {
             //每读取一次就写一次,读多少就写多少
             fos.write(buf, 0, hasRead);
         }
         System.out.println("write success");
     } catch (IOException e) {
         e.printStackTrace();
     }
 }
 
 public static void FileWriterTest() throws IOException {
     try (FileWriter fw = new FileWriter("text.rtf")) {
         fw.write("天王盖地虎\n");
         fw.write("宝塔镇河妖\n");
     } catch (IOException e) {
         e.printStackTrace();
     }
 }
 public static void main(String[] args) throws IOException {
     FileInputStreamTest();
     FileReaderTest();
     FileOutputStreamTest();
     FileWriterTest();
 }

}

PrintStream/PrintWriter/Scanner
StringReader/StringWriter
InputStreamReader/OutputStreamReader
BufferedReader/BufferedWriter , BufferedInputStream/BufferedOutputStream

package io;

import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.io.PushbackReader;
import java.io.StringReader;
import java.io.StringWriter;

public class TestIO {
public static void printStream() throws FileNotFoundException, IOException {
try (
FileOutputStream fos = new FileOutputStream(“tmp.txt”);
PrintStream ps = new PrintStream(fos)) {
ps.println(“普通字符串\n”);
//输出对象
ps.println(new TestIO());
} catch (IOException e) {
e.printStackTrace();
}
System.out.println(“输出完成”);

  }
  public static void stringNode() throws IOException {
      String str = "天王盖地虎\n"
              + "宝塔镇河妖\n";
      char[] buf = new char[32];
      int hasRead = 0;
      //StringReader将以String字符串为节点读取数据
      try (StringReader sr = new StringReader(str)) {
          while ((hasRead = sr.read(buf)) > 0) {
              System.out.print(new String(buf, 0, hasRead));
          }
      } catch (IOException e) {
          e.printStackTrace();
      }
      
      //由于String是一个不可变类,因此创建StringWriter时,实际上是以一个StringBuffer作为输出节点
      try (StringWriter sw = new StringWriter()) {
          sw.write("黑夜给了我黑色的眼睛\n");
          sw.write("我却用它寻找光明\n");
         //toString()返回sw节点内的数据
          System.out.println(sw.toString());
      } catch (IOException e) {
          e.printStackTrace();
     }
  }
  
  public static void keyIn() throws IOException {
      try (
              //InputStreamReader是从byte转成char的桥梁
             InputStreamReader reader = new InputStreamReader(System.in);
              //BufferedReader(Reader in)是char类型输入的包装类
              BufferedReader br = new BufferedReader(reader);
              ) {
          String line = null;
          while ((line = br.readLine()) != null) {
              if (line.equals("exit")) {
                  //System.exit(1);
                  break;
              }
              System.out.println(line);
          }
      } catch (IOException e) {
          e.printStackTrace();
      }
  }
  
 
  
 public static void main(String[] args) throws IOException {
     printStream();
     //stringNode();
     //keyIn();
 }

}

总结上面几种流的应用场景:

FileInputStream/FileOutputStream 需要逐个字节处理原始二进制流的时候使用,效率低下
FileReader/FileWriter 需要组个字符处理的时候使用
StringReader/StringWriter 需要处理字符串的时候,可以将字符串保存为字符数组
PrintStream/PrintWriter 用来包装FileOutputStream 对象,方便直接将String字符串写入文件
Scanner 用来包装System.in流,很方便地将输入的String字符串转换成需要的数据类型
InputStreamReader/OutputStreamReader , 字节和字符的转换桥梁,在网络通信或者处理键盘输入的时候用
BufferedReader/BufferedWriter , BufferedInputStream/BufferedOutputStream , 缓冲流用来包装字节流后者字符流,提升IO性能,BufferedReader还可以方便地读取一行,简化编程。
printStackTrace()方法的意思是:在命令行打印异常信息在程序中出错的位置及原因。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值