- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章InputStreamReader和BufferedReader用法及实例讲解由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
1、BufferedReader类 。
. 所属类库:
java.lang.Object 。
java.io.Reader 。
java.io.BufferedReader 。
. 基本概念 :
public class BufferedReader extends Reader 。
从字符输入流中读取文本,缓冲各个字符,从而实现字符、数组和行的高效读取。 可以指定缓冲区的大小,或者可使用默认的大小。大多数情况下,默认值足够大.
通常, Reader 所作的每个读取请求都会导致对底层字符或字节流进行相应的读取请求。因此,建议用 BufferedReader 包装所有其 read() 操作可能开销很高的 Reader (如 FileReader 和 InputStreamReader ).
BufferedReader 流能够读取文本行 , 通过向 BufferedReader 传递一个 Reader 对象 , 来创建一个 BufferedReader 对象 , 之所以这样做是因为 FileReader 没有提供读取文本行的功能 . 。
. Demo :
通过 Bufferedreader 捕获所输入的语句 :
1
2
3
4
5
6
7
8
9
10
|
import
java.io.*;
class
BufferedReaderDemo{
public
static
void
main(String[] args)
throws
IOException {
BufferedReader bufferedReader =
new
BufferedReader(
new
InputStreamReader(System.in));
System.out.print(
"请输入一系列文字,可包括空格:"
);
String text =bufferedReader.readLine();
System.out.println(
"请输入文字:"
+text);
}
}
|
注解:
throws IOException 抛出异常 。
InputStreamReader 是字节流通向字符流的桥梁 。
2、InputStreamReader类 。
InputStreamReader 将字节流转换为字符流。是字节流通向字符流的桥梁。如果不指定字符集编码,该解码过程将使用平台默认的字符编码,如:GBK.
构造方法 : 。
InputStreamReader isr = new InputStreamReader(InputStream in);//构造一个默认编码集的InputStreamReader类 InputStreamReader isr = new InputStreamReader(InputStream in,String charsetName);//构造一个指定编码集的 。
InputStreamReader类。 。
参数 in对象通过 InputStream in = System.in;获得。//读取键盘上的数据。 。
或者 InputStream in = new FileInputStream(String fileName);//读取文件中的数据。可以看出 FileInputStream 为InputStream的子类.
主要方法 :int read();//读取单个字符。 。
int read(char []cbuf);//将读取到的字符存到数组中。返回读取的字符数.
. Demo :
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
|
import
java.io.*;
class
InputStreamReaderDemo {
public
static
void
transReadNoBuf()
throws
IOException {
/**
* 没有缓冲区,只能使用read()方法。
*/
//读取字节流
//InputStream in = System.in;//读取键盘的输入。
InputStream in =
new
FileInputStream(
"D:\\demo.txt"
);
//读取文件的数据。
//将字节流向字符流的转换。要启用从字节到字符的有效转换,
//可以提前从底层流读取更多的字节.
InputStreamReader isr =
new
InputStreamReader(in);
//读取
//综合到一句。
//InputStreamReader isr = new InputStreamReader(
//new FileInputStream("D:\\demo.txt"));
char
[]cha =
new
char
[
1024
];
int
len = isr.read(cha);
System.out.println(
new
String(cha,
0
,len));
isr.close();
}
public
static
void
transReadByBuf()
throws
IOException {
/**
* 使用缓冲区 可以使用缓冲区对象的 read() 和 readLine()方法。
*/
//读取字节流
//InputStream in = System.in;//读取键盘上的数据
InputStream in =
new
FileInputStream(
"D:\\demo.txt"
);
//读取文件上的数据。
//将字节流向字符流的转换。
InputStreamReader isr =
new
InputStreamReader(in);
//读取
//创建字符流缓冲区
BufferedReader bufr =
new
BufferedReader(isr);
//缓冲
//BufferedReader bufr = new BufferedReader(
//new InputStreamReader(new FileInputStream("D:\\demo.txt")));可以综合到一句。
/*int ch =0;
ch = bufr.read();
System.out.println((char)ch);
*/
String line;
while
((line = bufr.readLine())!=
null
){
System.out.println(line);
}
isr.close();
}
}
|
3、InputStreamReader、BufferedReader真实案例(非编码集) 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
import
java.io.*;
class
UtilResource {
private
void
initializeResource() {
try
{
//读取文件,并且以utf-8的形式写出去
BufferedReader bufread;
String read;
bufread =
new
BufferedReader(
new
InputStreamReader(ResourceHelper
.getResourceInputStream(
"pinyin.txt"
)));
while
((read = bufread.readLine()) !=
null
) {
System.out.println(read);
}
bufread.close();
}
catch
(FileNotFoundException ex) {
ex.printStackTrace();
}
catch
(IOException ex) {
ex.printStackTrace();
}
}
}
|
注:其中 pinyin.txt 放于项目的根目录下 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import
java.io.BufferedInputStream;
import
java.io.FileInputStream;
import
java.io.FileNotFoundException;
class
ResourceHelper {
/**
* @param resourceName
* @return
* @return
*/
static
BufferedInputStream getResourceInputStream(String resourceName) {
try
{
return
new
BufferedInputStream(
new
FileInputStream(resourceName));
}
catch
(FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return
null
;
}
}
|
总结:
InputStreamReader 类 。
是字节流通向字符流的桥梁,封裝了InputStream在里头, 它以较高级的方式,一次读取一个一个字符,以文本格式输入 / 输出,可以指定编码格式; 。
BufferedReader 类 。
BufferedReader 由Reader类扩展而来,提供通用的缓冲方式文本读取,而且提供了很实用的readLine,读取一个文本行,从字符输入流中读取文本,缓冲各个字符,从而提供字符、数组和行的高效读取.
ps:InputStream、InputStreamReader和Reader的关系 。
InputStream:得到的是字节输入流,InputStream.read("filename")之后,得到字节流 。
Reader:读取的是字符流 。
InputStreamReader:从字节到字符的桥梁。InputStreamReader(InputStream.read("filename")),
reader.read(InputStreamReader(InputStream in));便可从字节变为字符,打印显示了.
java.io.Reader 和 java.io.InputStream 组成了Java 输入类.
Reader 用于读入16位字符,也就是Unicode 编码的字符;而 InputStream 用于读入 ASCII 字符和二进制数据.
Reader支持16位的Unicode字符输出,InputStream支持8位的字符输出.
Reader和InputStream分别是I/O库提供的两套平行独立的等级机构,1byte = 8bits InputStream、OutputStream是用来处理8位元的流,Reader、Writer是用来处理16位元的流.
而在JAVA语言中,byte类型是8位的,char类型是16位的,所以在处理中文的时候需要用Reader和Writer.
值得说明的是,在这两种等级机构下,还有一道桥梁InputStreamReader、OutputStreamWriter负责进行InputStream到Reader的适配和由OutputStream到Writer的适配.
在 Java中,有不同类型的 Reader 输入流对应于不同的数据源:
FileReader 用于从文件输入; CharArrayReader 用于从程序中的字符数组输入; StringReader 用于从程序中的字符串输入; PipedReader 用于读取从另一个线程中的 PipedWriter 写入管道的数据.
相应的也有不同类型的 InputStream 输入流对应于不同的数据源:FileInputStream,ByteArrayInputStream,StringBufferInputStream,PipedInputStream.
另外,还有两种没有对应 Reader 类型的 InputStream 输入流: Socket 用于套接字; URLConnection 用于 URL 连接。 这两个类使用 getInputStream() 来读取数据.
相应的,java.io.Writer 和 java.io.OutputStream 也有类似的区别.
关于InputStream.read(byte[] b)和InputStream.read(byte[] b,int off,int len)这两个方法都是用来从流里读取多个字节的,有经验的程序员就会发现,这两个方法经常 读取不到自己想要读取的个数的字节。比如第一个方法,程序员往往希望程序能读取到b.length个字节,而实际情况是,系统往往读取不了这么多。仔细阅读Java的API说明就发现了,这个方法 并不保证能读取这么多个字节,它只能保证最多读取这么多个字节(最少1个)。因此,如果要让程序读取count个字节,最好用以下代码:
1
2
3
4
5
|
byte
[] b =
new
byte
[count];
int
readCount =
0
;
// 已经成功读取的字节的个数
while
(readCount < count) {
readCount += in.read(bytes, readCount, count - readCount);
}
|
用这段代码可以保证读取count个字节,除非中途遇到IO异常或者到了数据流的结尾(EOFException) 。
最后此篇关于InputStreamReader和BufferedReader用法及实例讲解的文章就讲到这里了,如果你想了解更多关于InputStreamReader和BufferedReader用法及实例讲解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我可以做这个科目吗?我的意思是: BufferedReader reader1 = new BufferedReader(new FileReader(new File("file"))); Bu
这个问题已经有答案了: Unhandled Exception Type IOException [duplicate] (4 个回答) Java: import statement vs fully
PrintWriter out = new PrintWriter(DoDSocket.getOutputStream(), true); BufferedReader in = ne
我是java新手。我想从 java 启动的进程中读取标准输出。我在谷歌搜索中得到了以下代码: Runtime rt = Runtime.getRuntime(); Process pr
这个问题已经有答案了: Stream closed and not reopened - Java (2 个回答) Closing Reader/Stream in Java [duplicate]
我有一个片段如下: Process proc = Runtime.getRuntime().exec(command); BufferedReader br = new BufferedReader(
1. 概述 在这个例子中,我们将使用一个BufferedReader类来读取一个名为 "sample.txt "的文件。 BufferedReader类是用来从基于字符的
我正在 youtube 上查看有关 BufferedReader 的教程 https://www.youtube.com/watch?v=yofFVbARIRU 我完全按照他的方式编写代码,但我无法让
我正在尝试编写一个方法来获取一个多行制表符分隔的文件,并将该文件的内容作为字符串数组的数组列表返回(每一行都是一个字符串[],每个这样的字符串[]都是一个元素一个数组列表)。我的问题是,我无法判断输出
我需要从 Java InputStream 中读取以零结尾的字符串。 有没有类似BufferedReader.readLine()的读取零结尾字符串的方法? 最佳答案 package com; imp
String str = ""; try { BufferedReader br = new BufferedReader(new FileRe
我用下面的样式用BufferedReader读取文件 try (BufferedReader br = new BufferedReader(new FileReader("my_file"))) {
我正在编写一些使用clojure.async的函数,以从读取/写入套接字抽象出来。我的目的是可以将值放入 channel 中以进行写入,并从要读取的 channel 中弹出。这样,用户无需担心Read
我正在尝试使用缓冲读取器读取文件,但有时它会跳过一行中的第一个字符。这是我正在阅读的文件: http://files.moonmana.com/forums/Rectangle.h 这是我得到的结果:
我是 Java 新手,我正在尝试使用此类返回 "test.csv" 的内容。这只在我使用本地文件的路径时才有效。 public class CSVtoArray2 { public stati
我正在使用 BufferedReader.readLine() 逐行读取文本文件,但突然它不读取整行,而是只读取仅第一个字符串 示例:如果文本文件中的第一行是: [98.0,20.0,-65.0]
读完整个字符串后,读者会停留在 while 中,甚至不会抛出异常。我正在通过curl 向服务器发送请求。 我尝试更改 curl 的内容类型,更改字符串的内容,并使用另一种方式读取输入,例如扫描仪,但总
我正在使用 BufferedReader 从 ma url 获取数据。 URL url = new URL("http://"); BufferedReader in = new Buffered
我有一个缓冲阅读器,由于某种原因,它不会从我从客户端发送的打印流中读取文本。这是每次 line = in.readline 时失败的点 我也检查过并且服务器已连接。 这是错误 java.net.Soc
第一次这个循环迭代效果很好,但在我按字符“y”以重复之后,下次显示时,它不会让我输入另一个名称。我不知道是什么原因造成的,但是当你需要清除输入缓冲区时,它让我想起了 C。 任何帮助我们都将不胜感激。
我是一名优秀的程序员,十分优秀!