使用Reader.read()。返回值-1表示流的结尾;否则,强制转换为char。
此代码从文件参数列表中读取字符数据:
public class CharacterHandler {
//Java 7 source level
public static void main(String[] args) throws IOException {
// replace this with a known encoding if possible
Charset encoding = Charset.defaultCharset();
for (String filename : args) {
File file = new File(filename);
handleFile(file, encoding);
}
}
private static void handleFile(File file, Charset encoding)
throws IOException {
try (InputStream in = new FileInputStream(file);
Reader reader = new InputStreamReader(in, encoding);
// buffer for efficiency
Reader buffer = new BufferedReader(reader)) {
handleCharacters(buffer);
}
}
private static void handleCharacters(Reader reader)
throws IOException {
int r;
while ((r = reader.read()) != -1) {
char ch = (char) r;
System.out.println("Do something with " + ch);
}
}
}
上面的代码的坏处是它使用系统的默认字符集。尽可能使用已知的编码(如果可以选择,最好使用Unicode编码)。有关更多信息,请参见Charset类。(如果您受虐,可以阅读此字符编码指南。)
(您可能要注意的一件事是补充Unicode字符-需要存储两个char值的Unicode字符。有关更多详细信息,请参见Character类;这是一种边缘情况,可能不适用于家庭作业。)