该程序读取输入文件的行并将它们存储到数组字中。然后将[]中的每个元素放入一个字符数组中并按字母顺序排序。每个排序的字符数组都被分配给一个字符串,并且这些字符串填充另一个数组sortedWords。我需要排序sortedWords数组中的元素。当我使用Arrays.sort(sortedWords)时,我得到一个NullPointerException异常。使用java.util.Arrays.sort的NullPointerException()
public static void main(String[] args) throws FileNotFoundException {
Scanner scanner = new Scanner(System.in);
System.out.print("Enter a file name: ");
System.out.flush();
String filename = scanner.nextLine();
File file = new File(filename);
String[] words = new String[10];
String[] sortedWords = new String[10];
try {
FileReader fr = new FileReader(file);
BufferedReader br = new BufferedReader(fr);
String line = br.readLine();
int i = 0;
while(line != null) {
words[i] = line.toString(); // assigns lines into the array
line = br.readLine(); // this will eventually set line to null, terminating the loop
String signature = words[i];
char[] characters = signature.toCharArray();
Arrays.sort(characters);
String sorted = new String(characters);
sortedWords[i] = sorted; // assigns each signature into the array
sortedWords[i] = sortedWords[i].replaceAll("[^a-zA-Z]", "").toLowerCase(); // removes non-alphabetic chars and makes lowercase
Arrays.sort(sortedWords);
System.out.println(words[i] + " " + sortedWords[i]);
i++;
}
}
catch(IOException e) {
System.out.println(e);
}
}
希望你的文件只有10行。 –
@SotiriosDelimanolis yep – dk1