[英]Java sorting 2d talble error with Arrays.sort()
我在Java中的程序有一點問題。 我需要根據第一列按字母順序對String數組進行排序。 但是我收到一個奇怪的錯誤。 所以這是代碼:
import java.io.IOException;
import java.util.Arrays;
import java.util.Comparator;
public class Main {
public static void main(String[] args) throws IOException {
String[][] Dictionary= new String[10][2];
Dictionary[0][0]="a";
Dictionary[0][1]="5";
Dictionary[1][0]="c";
Dictionary[1][1]="6";
Dictionary[2][0]="b";
Dictionary[2][1]="2";
Dictionary[3][0]="f";
Dictionary[3][1]="8";
Dictionary[4][0]="z";
Dictionary[4][1]="9"; //the rest is empty
//i want it to be like this:
// a-5
// b-2
// c-6
// f-8
// z-9
// null-null
// null-null
// .
// .
// .
Arrays.sort(Dictionary, new Comparator<String[]>() { //<------
public int compare(final String[] entry1, final String[] entry2) {
final String time1 = entry1[0];
final String time2 = entry2[0];
return time1.compareTo(time2);
}
});
}
}
所以在我放置<----的那一行中,我得到了這兩個錯誤:
2.語法錯誤,僅當源級別為5.0時,參數化類型才可用
我不太確定比較器是如何工作的,我發現它在網上進行了一些修改,是我能盡力而為的,但仍然無法正常工作。 任何人有任何想法!
對於Java錯誤檢查: 更改Java編譯器版本您需要更改sort方法使其像這樣才能接受null
:
Arrays.sort(Dictionary, new Comparator<String[]>() { // <------
public int compare(final String[] entry1, final String[] entry2) {
final String time1 = entry1[0];
final String time2 = entry2[0];
if (time1 == null) {
return 1;
} else if (time2 == null) {
return -1;
}
return time1.compareTo(time2);
}
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.