Hashtable內部排列的方式是散列排布,所以當輸出信息時會是無序的。爲了能保證輸出的數據按照順序排列,不要渴望用java自帶的函數來對Hashtable對象進行調整處理。當我們獲取Hashtable裏的KEY和VALUE時,一般都運行了Map.Entry類來轉換,好,現在就用這個類來作文章,我具體寫了一個方法。
代碼:
/**
* 方法名稱:getSortedHashtable
* 參數:Hashtable h 引入被處理的散列表
* 描述:將引入的hashtable.entrySet進行排序,並返回
*/
public static Map.Entry[] getSortedHashtable(Hashtable h){
Set set = h.entrySet();
Map.Entry[] entries = (Map.Entry[])set.toArray(new Map.Entry[set.size()]);
Arrays.sort(entries,new Comparator(){
public int compare(Object arg0, Object arg1) {
Object key1 = ((Map.Entry)arg0).getKey();
Object key2 = ((Map.Entry)arg1).getKey();
return ((Comparable)key1).compareTo(key2);
}
});
return entries;
}
調用這個方法:
Map.Entry[] set = getSortedHashtable(t);
//perportyTable
for (int i=0;i<set.length;i++){
System.out.println(set[i].getKey().toString());
System.out.println(set[i].getValue().toString());
}
完畢。