set集合家族

tech2022-09-16  119

HashSet

java.util包下的类

构造方法

HashSet() 构造一个新的空 set,其底层 HashMap 实例的默认初始容量是 16,加载因子是 0.75。 HashSet(Collection<? extends E> c) 构造一个包含指定 collection 中的元素的新 set。 HashSet(int initialCapacity) 构造一个新的空 set,其底层 HashMap 实例具有指定的初始容量和默认的加载因子(0.75) HashSet(int initialCapacity, float loadFactor) 构造一个新的空 set,其底层 HashMap 实例具有指定的初始容量和指定的加载因子。

无序无重复:是指集合存放的顺序和取得元素的顺序不一致

但集合内部有自己的算法排布顺序,hash算法

HashSet的无重复原则是equals方法和HashCode方法同时进行比较

如果发现重复元素了,就拒绝存入了

迭代器

/** * 遍历集合元素 * Collection提供了统一的遍历集合元素的操作:迭代器模式 * * Iterator iterator() * 该方法会返回一个用于遍历该集合的迭代器,使用这个迭代器 * 便可以遍历当前集合元素。 * * java.util.Iterator接口 * 它是所有迭代器的顶级接口,不同的集合都实现了一个用于遍历 * 自身元素的迭代器实现类。 * 迭代器遍历集合遵循的原则为:问,取,删 * 其中删除元素不是遍历过程中的必要操作。 */ public static void main(String[] args) { Collection c = new ArrayList(); c.add("java"); c.add("c++"); c.add("小孩"); c.add("张三"); //获取迭代器 Iterator i = c.iterator(); /* * boolean hasNext() * 判断集合是否还有下一个元素可以迭代 */ while(i.hasNext()){ /* * E next() * 获取集合下一个元素 */ String str = (String) i.next(); System.out.println(str); /* * 迭代器要求在遍历的过程中不得使用集合 * 的方法增删元素,否则遍历时会抛出异常 */ /* * 迭代器也提供了remove方法,删除是通过 * next方法取出的元素。 */ i.remove(); } }

泛型和增强for循环

/** * JDK5之后推出了一个特性:增强for循环 * 也称为新循环,for each. * 新循环不是用来取代传统for循环的操作, * 而仅用来遍历集合 或数组使用。 * 编译器会将新循环遍历集合改为迭代器遍历 * 所以在遍历的过程中不能通过集合的方法增删元素 * */ /** * JDK5版本推出时,推出了一个特性:泛型 * 泛型又称为参数化类型,允许我们在使用一个类时指定其属性 * 方法参数以及返回值的类型。使得代码的灵活度提高。 * * 泛型应用最广的地方就是集合,用来约束集合的元素类型。 * * 迭代器也可以指定泛型类型,与其遍历的集合泛型一致即可 * */

TreeSet

java.util包下的类

无序无重复

TreeSet本身有顺序,是按照字典索引顺序排布的 TreeSet要求存入的类实现Comparable接口,重写方法

最新回复(0)