zoukankan      html  css  js  c++  java
  • HashSet与HashMap的区别

    HashSet与HashMap的区别

    1.HashSet:

      HashSet实现了Set接口,它不允许集合中出现重复元素。当我们提到HashSet时,第一件事就是在将对象存储在

    HashSet之前,要确保重写hashCode()方法和equals()方法,这样才能比较对象的值是否相等,确保集合中没有

    储存相同的对象。如果不重写上述两个方法,那么将使用下面方法默认实现:

     public boolean add(Object obj)方法用在Set添加元素时,如果元素值重复时返回 "false",如果添加成功则返回"true"


    2.HashMap:

      HashMap实现了Map接口,Map接口对键值对进行映射。Map中不允许出现重复的键(Key)。Map接口有两个基本的实现

    TreeMap和HashMap。TreeMap保存了对象的排列次序,而HashMap不能。HashMap可以有空的键值对(Key(null)-Value(null))

    HashMap是非线程安全的(非Synchronize),要想实现线程安全,那么需要调用collections类的静态方法synchronizeMap()实现。

    public Object put(Object Key,Object value)方法用来将元素添加到map中。

    3.HashSet与HashMap的区别:

    (1)HashMap	                               
    	a.实现了Map接口	                        
    	b.存储键值对	                            
    	c.调用put()向map中添加元素				
    	d.HashMap使用键(Key)计算Hashcode		
    	e.HashMap相对于HashSet较快,				
    	因为它是使用唯一的键获取对象			
    (2)HashSet
    	a.实现Set接口
    	b.仅存储对象
    	c.调用add()方法向Set中添加元素
    	d.HashSet使用成员对象来计算hashcode值,
    	  对于两个对象来说hashcode可能相同,
    	  所以equals()方法用来判断对象的相等性,
    	  如果两个对象不同的话,那么返回false
    	e.HashSet较HashMap来说比较慢
    

     

      

  • 相关阅读:
    Python在信号与系统(1)——Hilbert兑换,Hilbert在国家统计局的包络检测应用,FIR_LPF滤波器设计,格鲁吉亚也迫使高FM(PM)调制
    HDU 4925 Apple Tree
    [ACM] HDU 3395 Special Fish (最大重量二分图匹配,KM算法)
    OCP解决问题053-16 MEMORY_TARGET
    图像归一化
    我毕业10年
    静态分析与动态分析
    逐步求精
    抽象与逐步求精
    自项向下,逐步求精
  • 原文地址:https://www.cnblogs.com/zhusf/p/10572350.html
Copyright © 2011-2022 走看看