Java核心包 java.io包介绍
IO: Input / Ouput 即输入输出
- 输出流:程序(内存) —>外界设备
- 输入流:外界设备—>程序(内存)
处理理数据类型分类
- 字符流:处理字符相关,如处理文本数据(如txt文件), Reader/Writer
- 字节流: 处理字节相关,如声音或者图片等二进制,InputStream/OutputStream
两者区别:
- 字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节
- 字节流可以处理几乎所有文件,字符流只能处理字符类型的数据
功能不同,但是具有共性内容,通过不断抽象形成4个抽象类,抽象类下面有很多子类是具体的实现
- 字符流 Reader/Writer
- 字节流 InputStream/OutputStream
IO流相关类体系概览
Java输入流Inputstream讲解
InputStream是输入字节流的父类,它是一个抽象类(一般用他的子类)
1
2
3
4
5
6
7
8
9
10
11
12
|
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用来具体实现类的创建对象,文件字节输入流,对文件数据以字节的形式进行读取操作
- 常用构造函数
1
2
3
4
|
//传⼊入⽂文件所在地址 public FileInputStream(String name) throws FileNotFoundException //传⼊入⽂文件对象 public FileInputStream(File file) throws FileNotFoundException |
例如:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
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流内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/ruan_luqingnian/article/details/113790688