`

IdentityHashMap

    博客分类:
  • Java
 
阅读更多

Java中的hashMap是不允许有重复的key存在的,那么什么才是重复的呢?其实就是说什么才是相等的?

Hashmap中用equal来判断相等。

IdentityHashMap中用==来判断相等。

 

例子:

public class IdentityHashMapTst {
	public static void main(String[] args) {
		Map<Integer,String> map1 = new HashMap<Integer,String>();
		Map<Integer,String> map2 = new IdentityHashMap<Integer,String>();
		
		Integer i1, i2;
		
		i1 = 1;
		i2 = 1;
		System.out.println("== \t"+ (i1==i2));
		System.out.println("equals \t"+ (i1.equals(i2)));
		
		map1.put(i1, "22");		map1.put(i2, "22");
		map2.put(i1, "22");		map2.put(i2, "22");
		System.out.println(map1.keySet().size());
		System.out.println(map2.keySet().size());

		i1 = 555;
		i2 = 555;
		System.out.println("== \t"+ (i1==i2));
		System.out.println("equals \t"+ (i1.equals(i2)));

		map1.put(i1, "22");		map1.put(i2, "22");
		map2.put(i1, "22");		map2.put(i2, "22");
		System.out.println(map1.keySet().size());
		System.out.println(map2.keySet().size());
	}
}

 

 

运行结果:

写道
== true
equals true
1
1
== false
equals true
2
3

 

分享到:
评论

相关推荐

    JAVA中IdentityHashMap使用.rar

    在Java编程语言中,`IdentityHashMap`是`java.lang.identityhashmap`包下的一种特殊映射类,它与我们常见的`HashMap`有所不同。`HashMap`基于键的`equals()`方法来判断键是否相等,而`IdentityHashMap`则是基于对象...

    java集合-IdentityHashMap的使用

    IdentityHashMap是Java中的一种特殊的哈希表实现,它使用"引用相等"(而不是"对象相等")来判断键的唯一性。具体来说,当且仅当两个键引用同一个对象时,它们被认为是相等的。

    集合Map

    《深入理解Java集合框架:IdentityHashMap的特殊魅力》 在Java集合框架中,Map接口扮演着重要的角色,它用于存储键值对数据。而在众多的Map实现中,IdentityHashMap是一个特殊的成员,它的行为与我们常见的HashMap...

    java中级面试题(自己汇总)

    本文总结了Java中级面试题,涵盖了集合、HashMap、HashSet、HashTable、ConcurrentHashMap、红黑树、Java 8对HashMap的优化、LinkedHashMap、TreeMap、IdentityHashMap等知识点。 集合 * List和Set都是继承自...

    Java中大集合

    本文将深入探讨标题中提到的HashMap类、IdentityHashMap类、SortedMap接口以及自定义类在Map中的使用,以及随机数在集合中的应用。 首先,HashMap类是Java中最常用的Map实现之一,它基于哈希表,提供了O(1)的平均...

    picketlink-jbas-common-2.6.0.CR4.zip

    在标准的Java库中,IdentityHashMap依赖对象的引用地址(而非equals()方法)来确定键值对的唯一性,而WeakHashMap则使用弱引用,当键被垃圾收集器回收时,键值对也会自动从映射中移除。 WeakIdentityHashMap则是将...

    java中集合的用法与区别.docx

    Map接口的实现类有Hashtable、HashMap、LinkedHashMap、WeakHashMap和IdentityHashMap。Hashtable与HashMap类似,但它是线程安全的,不接受null键值。HashMap是非同步的,允许null键和null值。LinkedHashMap保持了...

    set,list,map区别与联系.docx

    - **WeakHashMap**和**IdentityHashMap**:特殊类型的Map,WeakHashMap的键使用弱引用,键在不再被引用时会被自动清理;IdentityHashMap使用对象的引用地址而非equals()方法来判断键的相等性。 4. **关联操作** -...

    java集合与通用集合

    其中,`HashMap`提供基本的键值对存储,`TreeMap`支持有序遍历,`LinkedHashMap`保持插入顺序,`IdentityHashMap`使用`==`比较键值,而`WeakHashMap`的键依赖于垃圾收集器。 在J2SDK集合框架中,`Collections`类...

    2019阿里内推面经1

    最后,`IdentityHashMap`是一个特殊版本的哈希表,它使用对象的内存地址(`==`比较)来判断键是否相等,而不是通过`equals()`方法。这意味着即使两个键的`equals()`方法返回`true`,如果它们不是同一个对象实例,`...

    jdk 的集合框架的主体结构

    `LinkedHashMap`保持键的插入顺序,`IdentityHashMap`使用`==`来判断键值对的相等性,而`WeakHashMap`的键是弱引用,当无其他引用指向键时,键会被垃圾回收。 迭代器(Iterator)是Java集合框架的重要部分,它提供...

    Java 集合框架高难度进阶版面试题集锦解析

    - IdentityHashMap 使用对象的引用相等性而非对象的equals()方法来判断键是否相同。 - HashMap 默认使用对象的equals()和hashCode()方法来比较键。 16. Iterator 和 Enumeration 的区别: - Iterator 支持删除...

    Java期末复习-类集框架

    `HashMap`、`Hashtable`、`TreeMap`、`WeakHashMap`和`IdentityHashMap`是它的常见实现。 - `HashMap`是非线程安全的,而`Hashtable`是线程安全的。`TreeMap`按照键的自然顺序或自定义`Comparator`排序。 - `...

    java的总结

    `HashMap`基于哈希表实现,根据键的`equals()`方法进行键值对查找,而`IdentityHashMap`则根据键的引用相等性判断,适用于特殊情况。 10. **迭代器**:`Iterator`接口是Java集合框架的一部分,用于遍历集合中的元素...

    Java集合框架

    `IdentityHashMap`比较键时使用`==`而非`equals()`方法;`WeakHashMap`是一种特殊的`HashMap`,其键使用弱引用,一旦键不再被引用,就会被垃圾回收。`HashTable`是线程安全的`Map`实现,但不推荐在现代Java中使用,...

    map,list,set,stack,queue,vector等区别和特点1

    IdentityHashMap与HashMap类似,但其比较键时使用的是Object的`==`操作,而不是`equals()`方法,这意味着它基于对象的内存地址而非内容进行比较。 Stack是一个特殊的List,它是Vector的子类,实现了后进先出(LIFO...

    Java 软件开发复习提纲.pdf

    如ArrayList、Vector、LinkedList、Stack、HashSet、TreeSet、LinkedHashSet、PriorityQueue、HashMap、TreeMap、LinkedHashMap、Hashtable、IdentityHashMap、WeakHashMap。Collections类提供了一些通用的集合操作...

    set,list,map区别与联系.pdf

    `WeakHashMap`和`IdentityHashMap`则分别使用弱引用和对象身份作为键的比较标准。 选择哪种数据结构取决于具体的需求,如是否需要保持元素顺序、是否需要去重、是否需要快速查找等。理解这些基础数据结构的特性有助...

    Koloboke高性能的Java集合

    Koloboke的核心在于其实现了原生(native)的Java集合接口,如HashSet、HashMap和IdentityHashMap等。这些原生实现充分利用了Java的JNI(Java Native Interface)技术,直接与底层操作系统交互,从而避免了Java对象...

Global site tag (gtag.js) - Google Analytics