我有几个用 Java 读取的字典文件,在逐行读取它们时,我使用以下代码:
public static void main(String args[]) {
try {
FileInputStream fstream1 = new FileInputStream("de-DE.dic");
DataInputStream in = new DataInputStream(fstream1);
BufferedReader br = new BufferedReader(new InputStreamReader(in,"UTF-8"));
String str;
while ((str = br.readLine()) != null) {
String str_uc=str.toUpperCase(Locale.GERMAN);
if(hasApostrophe(str_uc)){
allletters.add(str_uc);
if(str.length()==3)
threeletter.add(str_uc);
else if(str.length()==4)
fourletter.add(str_uc);
else if(str.length()==5)
fiveletter.add(str_uc);
else if(str.length()==6)
sixletter.add(str_uc);
else if(str.length()==7)
sevenletter.add(str_uc);
}
}
in.close();
}
catch (Exception e) {
System.err.println(e);
}
但是,它总是在第一行单词中添加一个空字符,例如,如果第一行中包含三个字母的单词,则将其添加到四字母数组中。我怎样才能防止这种情况发生?谢谢。
添加:
这是文件中的几行:
Aachens
Aachen
Aal
Aale
Aalen
Aales
Aals
Aas
Aases
Aasgeier
Aasgeiern
Aasgeiers