JavaでのSetのソースコードの簡易解析

不言
リリース: 2018-09-20 15:22:25
オリジナル
2279 人が閲覧しました

この記事では、Java の Set のソース コードを簡単に分析します。必要な方は参考にしていただければ幸いです。

Set インターフェイスはコレクション インターフェイスを継承し、内部のメソッドはすべてコレクション内に存在します。

Set の主な実装クラスは、HashSet、TreeSet

です。 HashSet のソースコード

//HashSet的继承关系
public class HashSet<E>    
extends AbstractSet<E>    
implements Set<E>, Cloneable, java.io.Serializable
ログイン後にコピー

//由此可以看出hashSet底层实现是用HashMap
private transient HashMap<E,Object> map;
public HashSet() {
        map = new HashMap<>();
    }
ログイン後にコピー

次のメソッドにより、HashSet の実装メソッドが次のとおりであることがわかります。マップ操作

//遍历    
    public Iterator<E> iterator() {
           return map.keySet().iterator();
    }
    //计算长度
    public int size() {
        return map.size();
    }
    //判断是否为空
    public boolean isEmpty() {
        return map.isEmpty();
    }
    //添加
     public boolean add(E e) {
        return map.put(e, PRESENT)==null;
    }
ログイン後にコピー

TreeSet ソース コード

//TreeSet的继承关系
public class TreeSet<E> extends AbstractSet<E>    
implements NavigableSet<E>, Cloneable, java.io.Serializable
ログイン後にコピー

以上がJavaでのSetのソースコードの簡易解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!