14
2021
02

Java进阶核心之InputStream流深入讲解

Java核心包java.io包介绍

IO: Input / Ouput 即输入输出


  • 输出流:程序(内存) —>外界设备

  • 输入流:外界设备—>程序(内存)

处理理数据类型分类


  • 字符流:处理字符相关,如处理文本数据(如txt文件), Reader/Writer

  • 字节流: 处理字节相关,如声音或者图片等二进制,InputStream/OutputStream

两者区别:


  • 字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节

  • 字节流可以处理几乎所有文件,字符流只能处理字符类型的数据

功能不同,但是具有共性内容,通过不断抽象形成4个抽象类,抽象类下面有很多子类是具体的实现


  • 字符流 Reader/Writer

  • 字节流 InputStream/OutputStream

IO流相关类体系概览

2021212113222736.png



Java输入流Inputstream讲解

InputStream是输入字节流的父类,它是一个抽象类(一般用他的子类)


int read()

讲解:从输⼊入流中读取单个字节,返回0到255范围内的int字节值,字节数据可直接转换为int类

型, 如果已经到达流末尾⽽而没有可⽤用的字节,则返回- 1

int read(byte[] buf)

讲解:从输⼊入流中读取⼀一定数量量的字节,并将其存储在缓冲区数组buf中, 返回实际读取的字节

数,如果已经到达流末尾⽽而没有可⽤用的字节,则返回- 1

long skip(long n)

讲解:从输⼊入流中跳过并丢弃 n 个字节的数据。

int available()

讲解:返回这个流中有多少个字节数,可以把buf数组⻓长度定为这个

void close() throws IOException

讲解:关闭输⼊入流并释放与该流关联的系统资源


常见子类


FilelnputStream


  • 抽象类InputStream用来具体实现类的创建对象,文件字节输入流,对文件数据以字节的形式进行读取操作

  • 常用构造函数


//传⼊入⽂文件所在地址

public FileInputStream(String name) throws FileNotFoundException

//传⼊入⽂文件对象

public FileInputStream(File file) throws FileNotFoundException


例如:



package domee.chapter10_2;


import java.io.*;


public class Main {


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


  String dir = "C:\\Users\\阮相歌\\Desktop\\test";


  String name = "a.txt";


  File file = new File(dir,name);


  InputStream inputStream = new FileInputStream(file);


  testRead(inputStream);

  testSkip(inputStream);

  testReadByteArr(inputStream);

 }




 public static void testReadByteArr(InputStream inputStream)throws IOException{


  //如果buf的长度为0,则不读取任何字节并返回0;每次读取的字节数最多等于buf的长度

  //byte[] buf = new byte[1024];

  byte[] buf = new byte[inputStream.available()];


  int length;


  //循环读取文件内容,输入流中将最多的buf.length

  // 个字节数据读入一个buf数组中,返回类型是读取到的字节数

  //如果这个缓冲区没有满的话,则返回真实的字节数

  while ((length = inputStream.read(buf))!= -1){



   //中文乱码问题,换成GBK,或者UTF-8

   System.out.print(new String(buf,0,length));

   System.out.print(new String(buf,0,length,"UTF-8"));

   System.out.println(new String(buf,0,length));

  }

 }

 public static void testRead(InputStream inputStream)throws IOException{


  //对于汉字等 unicode中的字符不能正常读取,只能以乱码的形式显示

  int read = inputStream.read();

  System.out.println(read);

  System.out.println((char)read);

 }

 public static void testSkip(InputStream inputStream)throws IOException{


  long skipSize = inputStream.skip(2);

  System.out.println(skipSize);


  int read = inputStream.read();

  System.out.println(read);

  System.out.println((char)read);

 }

}


编码小知识(节省空间)


操作的中文内容多则推荐GBK:


GBK中英文也是两个字节,用GBK节省了空间,UTF-8编码的中文使用了三个字节

o如果是英文内容多则推荐UFT-8:


因为UFT-8里面英文只占一个字节

UTF-8编码的中文使用了三个字节

« 上一篇 下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。