Java进阶核心之InputStream流

Java进阶核心之InputStream流

Java核心包 java.io包介绍

  • IO: Input / Ouput 即输入输出
    • 输出流:程序(内存) —>外界设备
    • 输入流:外界设备—>程序(内存)
  • 处理理数据类型分类
    • 字符流:处理字符相关,如处理文本数据(如txt文件), Reader/Writer
    • 字节流: 处理字节相关,如声音或者图片等二进制,InputStream/OutputStream
  • 两者区别:
    • 字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节
    • 字节流可以处理几乎所有文件,字符流只能处理字符类型的数据
  • 功能不同,但是具有共性内容,通过不断抽象形成4个抽象类,抽象类下面有很多子类是具体的实现
    • 字符流 Reader/Writer
    • 字节流 InputStream/OutputStream
  • IO流相关类体系概览
    Java进阶核心之InputStream流_第1张图片

Java输入流Inputstream讲解

  • InputStream是输入字节流的父类,它是一个抽象类(一般用他的子类)
int read()
讲解:从输⼊入流中读取单个字节,返回0255范围内的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,SE,java,编程语言,乱码)