美文网首页
数据结构——Set

数据结构——Set

作者: 咸鱼有梦想呀 | 来源:发表于2019-03-27 09:40 被阅读0次

Set
Set 继承于 Collection 接口,是一个不允许出现重复元素,并且无序的集合,主要 HashSet 和 TreeSet 两大实现类。

在判断重复元素的时候,Set 集合会调用 hashCode()和 equal()方法来实现。

  • 有序集合:
    集合里的元素可以根据 key 或 index 访问 (List、Map)
  • 无序集合:
    集合里的元素只能遍历。(Set)

HashSet 和 TreeSet 底层数据结构

  • HashSet
    哈希表结构,主要利用 HashMap 的 key 来存储元素,计算插入元素的 hashCode 来获取元素在集合中的位置;
  • TreeSet
    红黑树结构,每一个元素都是树中的一个节点,插入的元素都会进行排序;

Set接口常用方法
Set接口继承Collection有以下方法:

添加:

添加

删除:


删除

获取长度

获取长度

判断

判断

获取迭代器

获取集合迭代器

集合转数组

将集合转化为数组
public interface Set<E> extends Collection<E> {

    //添加
    boolean add(E e);
    boolean addAll(Collection<? extends E> c);

    //删除
    boolean remove(Object o);
    boolean removeAll(Collection<?> c);
    void clear();

    //获取长度
    int size();

    //判断
    boolean isEmpty();
    boolean contains(Object o);
    boolean containsAll(Collection<?> c);
    boolean retainAll(Collection<?> c); 
    //判断元素是否重复,为子类提高重写方法
    boolean equals(Object o);
    int hashCode();

    //获取Set集合的迭代器
    Iterator<E> iterator();

    //把集合转换成数组
    Object[] toArray();
    <T> T[] toArray(T[] a);
   
}

详见:
https://www.jianshu.com/p/e2f4d647348e

相关文章

  • new Set去重的用法

    使用Set数据结构去除重复对象:new Set(strings)进行转型。因为Set数据结构并非真正的数组,它类似...

  • 【List、Set、数据结构、Collections】

    【List、Set、数据结构、Collections】 主要内容 数据结构 List集合 Set集合 Collec...

  • ES6中的Set和Map

    ES6中新增了Set、WeakSet、Map、WeakMap数据结构 一、Set Set是类似数组的数据结构,和数...

  • Redis数据结构

    Redis数据结构:有五种数据结构:Strings,Hansh,List,Set,Sorted Set Strin...

  • # day03 【List、Set、数据结构、Collectio

    day03 【List、Set、数据结构、Collections】 主要内容 数据结构 List集合 Set集合 ...

  • 步遥——Set和Map数据结构

    Set (集合)和Map (映射) 1:Set数据结构:Set新的数据结构,类似数组,但成员的值都是唯一的,没有重...

  • ES6中Set和Map数据结构

    Set 数据结构 一、基本用法 1、数据结构Set,类似于数组,成员的值都是唯一的,没有重复的值。 2、Set本身...

  • Set Map WeakSet WeakMap

    Set 集合的数据结构 Set集合新增了add, delete ,Set.size,has,keys,clear,...

  • 10-redis

    Redis: 1、数据结构:string, hash, list, set, sorted set 2、memca...

  • es6 Set

    ES6提供了数据结构Set。类似于数组,但是没有重复值。 Set本身是一个构造函数,用来生成Set数据结构 数组的...

网友评论

      本文标题:数据结构——Set

      本文链接:https://www.haomeiwen.com/subject/pndavqtx.html