gpt4 book ai didi

java - BufferedReader指针

转载 作者:行者123 更新时间:2023-12-01 15:51:59 25 4
gpt4 key购买 nike

我有以下代码,但我不明白如何将指针重置到起始位置:

BufferedReader inp=new BufferedReader(new FileReader(file));
Scanner leggi=new Scanner(inp);
for(int i=0;i<nwords;i++){
while(leggi.hasNext())
if(leggi.next().equals(args[i+2]))
occorrenze[i]=occorrenze[i]+1;
}
inp.close();

我试过了

inp.mark(0);
inp.reset();

没有结果。

最佳答案

保罗,

我建议您阅读这个旧线程:Java BufferedReader back to the top of a text file? .

我个人更喜欢 Jon Skeet 的回答,归根结底就是“不要打扰[除非你必须]。”

干杯。基思。

<小时/>

编辑:此外,即使遇到异常,您也应该始终关闭该输入文件。 finally block 非常适合此目的。

<小时/>

编辑2:

希望您仍然和我们在一起。

这是我的尝试,FWIW,您不需要重置输入文件,您只需要转置 whilefor 循环即可。

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非常适合构建频率表... Parallel arrays都是90后。 Map 的“默认”实现是 HashMap 类...默认情况下,我的意思是只要您需要 Map 就使用 HashMap,除非您有充分的理由使用其他东西,而这不会经常。 HashMap 通常是最好的全能执行器。

关于java - BufferedReader指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5841172/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com