评论

收藏

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

编程语言 编程语言 发布于:2021-09-12 12:47 | 阅读数:350 | 评论:0

这篇文章主要给大家介绍了关于Java进阶核心之InputStream流的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
Java核心包 java.io包介绍
IO: Input / Ouput 即输入输出

  • 输出流:程序(内存) —>外界设备
  • 输入流:外界设备—>程序(内存)
处理理数据类型分类

  • 字符流:处理字符相关,如处理文本数据(如txt文件), Reader/Writer
  • 字节流: 处理字节相关,如声音或者图片等二进制,InputStream/OutputStream
两者区别:

  • 字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节
  • 字节流可以处理几乎所有文件,字符流只能处理字符类型的数据
功能不同,但是具有共性内容,通过不断抽象形成4个抽象类,抽象类下面有很多子类是具体的实现

  • 字符流 Reader/Writer
  • 字节流 InputStream/OutputStream
IO流相关类体系概览
DSC0000.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编码的中文使用了三个字节
总结
到此这篇关于Java进阶核心之InputStream流的文章就介绍到这了,更多相关Java InputStream流内容请搜索CodeAE代码之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持CodeAE代码之家!
原文链接:https://blog.csdn.net/ruan_luqingnian/article/details/113790688

关注下面的标签,发现更多相似文章