set集合遍历方法

因为Set接口继承Collection接口,它与List集合的区别就是:List集合可以保存重复的数据,而Set集合不可以

此外,Set接口有三个常用实现类:

  1.HashSet,特点:

  • 它不按照存储的顺序保存,具有不确定性,也就是说每一次遍历集合出的元素排序不一定相同;
  • 允许使用null元素

 

  2.LinkedHashSet,特点:

  • 它是HashSet的子类,但它却是按照自然顺序保存的(不是简单的线性顺序)
  • 由于该实现类对象维护者一个运行于所有元素的双重链接列表,且该链接列表定义了一个迭代顺序(从名字上就可以看出Linked,被链接的,各个元素之间有一定的关系),
  • 所以在遍历该实现类集合时按照元素的插入顺序进行遍历


  3.TreeSet,特点:

  • 及实现Set接口,也实现了SortedSet接口,具有排序功能
  • 存入TreeSet中的对象元素需要实现Comparable接口

 

 如下有一个set集合:

  Set<String> names = new HashSet<String>();//多态,<String>泛型,用于限制存入集合中的元素的数据类型

  //add(Object element)用于向集合中添加元素,添加成功返回true,否则返回false
  System.out.println(names.add("刘一"));//true
  System.out.println(names.add("陈二"));//true
  System.out.println(names.add("张三"));//true
  System.out.println(names.add("张三"));//false


1.增强型for循环(for-each

  for(String name:names){

    System.out.println(name);

   }

2.迭代器遍历

  Iterator<String> iterator = names.iterator();//<String>泛型
  while(iterator.hasNext()){ //hasNext()用于判断是否含有下一个元素
    System.out.println(iterator.next());//next()用于指向下一个元素
  }

 

上一篇:前端实现拉新——table增删改查


下一篇:day6-元组和字典