HashSet集合介绍
生活随笔
收集整理的這篇文章主要介紹了
HashSet集合介绍
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Set接口
java.util.Set接口和java.util.List接口一樣,同樣繼承自Collection接口,它與Collection接口中的方法基本一致,并沒有對Collection接口進行功能上的擴充,只是比Collection接口更加嚴格了。與List接口不同的是,Set接口中元素無序,并且都會以某種規則保證存入的元素不出現重復。
Set集合有多個子類,這里我們介紹其中的java.util.HashSet、java.util.LinkedHashSet這兩個集合。
tips:Set集合取出元素的方式可以采用:迭代器、增強for。
HashSet集合介紹
java.util.HashSet是Set接口的一個實現類,它所存儲的元素是不可重復的,并且元素都是無序的(即存取順序不一致)。java.util.HashSet底層的實現其實是一個java.util.HashMap支持,由于我們暫時還未學習,先做了解。
HashSet是根據對象的哈希值來確定元素在集合中的存儲位置,因此具有良好的存取和查找性能。保證元素唯一性的方式依賴于:hashCode與equals方法。
我們先來使用一下Set集合存儲,看下現象,再進行原理的講解:
package com.learn.demo02.Set;import java.util.HashSet; import java.util.Iterator; import java.util.Set;/*java.util.Set接口 extends Collection接口Set接口的特點:1.不允許存儲重復的元素2.沒有索引,沒有帶索引的方法,也不能使用普通的for循環遍歷java.util.HashSet集合 implements Set接口HashSet特點:1.不允許存儲重復的元素2.沒有索引,沒有帶索引的方法,也不能使用普通的for循環遍歷3.是一個無序的集合,存儲元素和取出元素的順序有可能不一致4.底層是一個哈希表結構(查詢的速度非常的快)*/ public class Demo01Set {public static void main(String[] args) {Set<Integer> set = new HashSet<>();//使用add方法往集合中添加元素set.add(1);set.add(3);set.add(2);set.add(1);//使用迭代器遍歷set集合Iterator<Integer> it = set.iterator();while (it.hasNext()){Integer n = it.next();System.out.println(n);//1,2,3}//使用增強for遍歷set集合System.out.println("-----------------");for (Integer i : set) {System.out.println(i);}} }?
總結
以上是生活随笔為你收集整理的HashSet集合介绍的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: List集合_介绍常用方法
- 下一篇: HashSet集合存储数据的结构(哈希表