FileInputStream和FileReader的区别
1个回答
展开全部
Java中FileReader vs FileInputStream
由于FileReader类继承了InputStreamReader类,使用的字符编码,要么由类提供,要么是平台默认的字符编码。请记住,InputStreamReader会缓存的字符编码。创建对象后,设置字符编码将不会有任何影响。让我们来看看如何使用Java中InputStream和FileReader的例子。你可以提供任何一个文件对象或一个包含文件位置的字符串,以开始读取文件的字符数据。这类似于FileInputStream,也提供了类似的用于读取文件源的构造函数。尽管建议使用BufferedReader来读取文件数据。
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
import java.awt.Color;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
/**
* Java程序通过字节流和字符流的方式来读取文件数据。
* 需强调FileInputStream和FileReader的关键区别在于:FileReader用于读取字符流,而FileInputStream用来读取原始字节流。
* @author Javin Paul
*/
public class HowToReadFileInJava {
public static void main(String args[]) {
// 例1 – 使用FileInputStream 读取文件内容
try (FileInputStream fis = new FileInputStream("data.txt")) {
int data = fis.read();
while (data != -1) {
System.out.print(Integer.toHexString(data));
data = fis.read();
}
} catch (IOException e) {
System.out.println("Failed to read binary data from File");
e.printStackTrace();
}
// 例2 – Java中使用FileReader 读取文件数据
try (FileReader reader = new FileReader("data.txt")) {
int character = reader.read();
while (character != -1) {
System.out.print((char) character);
character = reader.read();
}
} catch (IOException io) {
System.out.println("Failed to read character data from File");
io.printStackTrace();
}
}
}
输出:
1
2
3
4
5
4157532d416d617a6f6e205765622053657276696365da474f4f472d476f6f676c65da4150504c2d4170706c65da47532d476f6c646d616e205361636873
AWS-Amazon Web Service
GOOG-Google
APPL-Apple
GS-Goldman Sachs
第1个例子是按字节从文件中读取数据,因此势必会非常慢。FileInputStream的read()
方法是阻塞式的,读取字节或数据块,直到无数据输入。它要么返回数据的下一个字节,当到达文件末尾时,返回-1。这意味着,我们每循环读取一个字节,将其打印为十六进制字符串。顺便说一句,将InputStream转换成字节数组是可选的。另一方面,例2是按字符读取数据。继承自FileReader的InputStreamReader
的read() 方法读取单个字符,并返回该字符,当到达流末尾时,返回-1。这就是为什么你看到例2输出的文字跟文件中的完全一样。
这就是所有关于Java中FileInputStream和FileReader之间的区别。归根结底:使用FileReader或BufferedReader从文件中读取字符或文本数据,并总是指定字符编码;使用FileInputStream从Java中文件或套接字中读取原始字节流。
由于FileReader类继承了InputStreamReader类,使用的字符编码,要么由类提供,要么是平台默认的字符编码。请记住,InputStreamReader会缓存的字符编码。创建对象后,设置字符编码将不会有任何影响。让我们来看看如何使用Java中InputStream和FileReader的例子。你可以提供任何一个文件对象或一个包含文件位置的字符串,以开始读取文件的字符数据。这类似于FileInputStream,也提供了类似的用于读取文件源的构造函数。尽管建议使用BufferedReader来读取文件数据。
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
import java.awt.Color;
import java.io.FileInputStream;
import java.io.FileReader;
import java.io.IOException;
/**
* Java程序通过字节流和字符流的方式来读取文件数据。
* 需强调FileInputStream和FileReader的关键区别在于:FileReader用于读取字符流,而FileInputStream用来读取原始字节流。
* @author Javin Paul
*/
public class HowToReadFileInJava {
public static void main(String args[]) {
// 例1 – 使用FileInputStream 读取文件内容
try (FileInputStream fis = new FileInputStream("data.txt")) {
int data = fis.read();
while (data != -1) {
System.out.print(Integer.toHexString(data));
data = fis.read();
}
} catch (IOException e) {
System.out.println("Failed to read binary data from File");
e.printStackTrace();
}
// 例2 – Java中使用FileReader 读取文件数据
try (FileReader reader = new FileReader("data.txt")) {
int character = reader.read();
while (character != -1) {
System.out.print((char) character);
character = reader.read();
}
} catch (IOException io) {
System.out.println("Failed to read character data from File");
io.printStackTrace();
}
}
}
输出:
1
2
3
4
5
4157532d416d617a6f6e205765622053657276696365da474f4f472d476f6f676c65da4150504c2d4170706c65da47532d476f6c646d616e205361636873
AWS-Amazon Web Service
GOOG-Google
APPL-Apple
GS-Goldman Sachs
第1个例子是按字节从文件中读取数据,因此势必会非常慢。FileInputStream的read()
方法是阻塞式的,读取字节或数据块,直到无数据输入。它要么返回数据的下一个字节,当到达文件末尾时,返回-1。这意味着,我们每循环读取一个字节,将其打印为十六进制字符串。顺便说一句,将InputStream转换成字节数组是可选的。另一方面,例2是按字符读取数据。继承自FileReader的InputStreamReader
的read() 方法读取单个字符,并返回该字符,当到达流末尾时,返回-1。这就是为什么你看到例2输出的文字跟文件中的完全一样。
这就是所有关于Java中FileInputStream和FileReader之间的区别。归根结底:使用FileReader或BufferedReader从文件中读取字符或文本数据,并总是指定字符编码;使用FileInputStream从Java中文件或套接字中读取原始字节流。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询