Hashtable排序

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());

  }

完畢。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章