老紫竹JAVA提高教程(3)-认识Set集合之LinkedHashSet

 
原文地址:http://www.java2000.net/p11794

有序的集合,就是LinkedList,内部通过双向链表实现,LinkedHashMap为基础。
  1. package collection.lession3;
  2. import java.util.Arrays;
  3. import java.util.HashSet;
  4. import java.util.LinkedHashSet;
  5. import java.util.Set;
  6. /**
  7.  * 老紫竹JAVA提高教程(3)-认识Set集合之LinkedHashSet。<br>
  8.  * <br>
  9.  * LinkedHashSet与HashSet的区别就是数据严格按照插入的顺序存放。<br>
  10.  * 删除之后会去掉那个位置,新增的数据将在集合的末尾。<br>
  11.  * HashSet 内部使用HashMap实现<br>
  12.  * 而LinkedHashSet内部使用LinkedHashMap实现。
  13.  * 
  14.  * @author 老紫竹 JAVA世纪网(java2000.net)
  15.  * 
  16.  */
  17. public class Lession3 {
  18.   public static void main(String[] args) {
  19.     test(new HashSet<Integer>());
  20.     test(new LinkedHashSet<Integer>());
  21.   }
  22.   public static void test(Set<Integer> set) {
  23.     System.out.println(set.getClass().getName());
  24.     // 增加10个数据
  25.     for (int i = 100; i <= 110; i++) {
  26.       set.add(i);
  27.     }
  28.     // 看看里面数据的情况
  29.     showSet(set);
  30.     // 删除一个数据
  31.     set.remove(101);
  32.     // 看看删除后的情况
  33.     showSet(set);
  34.     // 增加三个数据,看结果
  35.     set.add(98);
  36.     set.add(101);
  37.     set.add(118);
  38.     showSet(set);
  39.   }
  40.   /**
  41.    * 显示Set里面的数据。
  42.    * 
  43.    * @param set
  44.    */
  45.   private static void showSet(Set<Integer> set) {
  46.     System.out.println(Arrays.toString(set.toArray(new Integer[0])));
  47.   }
  48. }
测试:
    尝试按照自己的意愿,控制LinkedHashSet里面数据的顺序,比如删除第一个,再加入,则其出现在了末尾了。这个很像排队买票,一旦你中途退出了,就只能重新排队。是不允许加塞的。

总结:
  当我们处理集合,有想掌握其顺序的时候,可以考虑这个,当然List也是很好的选择,不过Hash算法,在查找数据的时候,比List性能要高的。

你可能感兴趣的:(java,.net,算法,list,String,HashMap)