ポール、
この古いスレッドを読むことをお勧めします: Java BufferedReader back to the top of a text file? .
個人的には、Jon Skeet の応答が好きです。これは、「気にしないでください [必要でない限り]」に要約されます。
乾杯。キース。
編集:また、例外に遭遇した場合でも、常にその入力ファイルを閉じる必要があります。ブロックはこれfinally
に最適です。
EDIT2:
あなたがまだ私たちと一緒にいることを願っています。
ここに私の試みがあります.FWIW、入力ファイルをリセットする必要はありません.andループwhile
を転置するだけです.for
package forums;
import java.util.Scanner;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
public class WordOccurrenceCount
{
public static void main(String[] args) {
try {
String[] words = { "and", "is", "a", "the", "of", "as" };
int[] occurrences = readOccurrences("C:/tmp/prose.txt", words);
for ( int i=0; i<words.length; i++ ) {
System.out.println(words[i] + " " + occurrences[i]);
}
} catch (Exception e) {
e.printStackTrace();
}
}
private static final int[] readOccurrences(String filename, String... words)
throws IOException
{
int[] occurrences = new int[words.length];
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader(filename));
Scanner scanner = new Scanner(reader);
while ( scanner.hasNext() ) {
String word = scanner.next();
for ( int i=0; i<words.length; i++ ) {
if ( words[i].equals(word) ) {
occurrences[i]++;
}
}
}
} finally {
if(reader!=null) reader.close();
}
return occurrences;
}
}
ところで、java.util.Mapは度数表を作成するのに最適です...並列配列はただの 90 年代です。Map の「デフォルト」実装はHashMap
クラスです...デフォルトでは、Map が必要なときはいつでも HashMap を使用することを意味します。HashMap は、一般的に最高のオールラウンド パフォーマーです。