在正常发育,HashMap,HashTable,HashSet 他们批准了经常使用的按键值地图数据结构.在这里,我主要写一些平时我们使用的这些数据结构easy忽略. HashMap HashMap的结构 HashMap 底层是一个Entry数组来支撑的.我认为叫Entry链表数组支撑更为合适. 结构图: 每一个entry数组里面的元素要么为null要么就是一个entry链表:而每一个entry对象就是一个entry链表的节点也是一个键值对的抽象表示: HashMap的性能因素 HashMap主要…
Java 集合 HashMap & HashSet 拾遗 @author ixenos 摘要:HashMap内部结构分析 Java HashMap采用的是冲突链表方式 从上图容易看出,如果选择合适的散列函数,put()和get()方法可以在常数时间内完成,因为较好的散列减少了散列冲突,使时间主要花在对桶寻址上(数组),而较少去遍历桶中的链表.但在对HashMap进行迭代时,需要遍历整个table以及后面跟的冲突链表.因此对于迭代比较频繁的场景,不宜将HashMap的初始大小设的过大. 有两个参数…
Hashtable: 1. key和value都不许有null值 2. 使用enumeration遍历 3. 同步的,每次只有一个线程能够访问 4. 在java中Hashtable是H大写,t小写,而HashMap是H大写,M大写 HashMap: 1. key和value可以有null值 2. 使用iterator遍历 3. 未同步的,多线程场合要手动同步HashMap HashSet 1. 底层调用HashMap 2. 不允许有重复值 常用Java操作:          hm.contai…
今天遇到一个bug,简单的说就是把自定义对象作为key 存到HashMap中之后,经过一系列操作(没有remove操作)之后 用该对象到map中取,返回null. 然后查看了HashMap的源代码,get方法的核心代码如下: final Entry<K,V> getEntry(Object key) { int hash = (key == null) ? 0 : hash(key); for (Entry<K,V> e = table[indexFor(hash, table.l…
基础内容 容器就是一种装其他各种对象的器皿.java.util包 容器:Set, List, Map ,数组.只有这四种容器. Collection(集合) 一个一个往里装,Map 一对一对往里装. Set:没有顺序,不可以重复. List:有顺序,可以重复. 互相的equals就算重复. Map定义了存储Key-Value的方法. Collection里装的必须都是Object,不能是基础类型.比如Int类型的值分配在栈上,而栈上的内容都是动态的. 容器类对象在调用remove,cotains…
在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList.HashMap.HashSet,也有不常用的Stack.Queue,有线程安全的Vector.HashTable,也有线程不安全的LinkedList.TreeMap等等! 上面的图展示了整个集合大家族的成员以及他们之间的关系.下面就上面的各个接口.基类做一些简单的介绍(主要介绍各个集合的特点.区别…
hash code.equals和“==”三者的关系 1) 对象相等则hashCode一定相等: 2) hashCode相等对象未必相等. == 是比较地址是否相等,JAVA中声明变量都是引用嘛,不同的引用,可能指向同一个地址. equals 是比较值是否相等. 1.如果是基本变量,没有hashcode和equals方法,基本变量的比较方式就只有==,: 2.如果是变量,由于在java中所有变量定义都是一个指向实际存储的一个句柄(你可以理解为c++中的指针),在这里==是比较句柄的地址(你可以理…
一,遍历方法的实现原理 1.传统的for循环遍历,基于计数器的: 遍历者自己在集合外部维护一个计数器,然后依次读取每一个位置的元素,当读取到最后一个元素后,停止.主要就是需要按元素的位置来读取元素. 2.迭代器遍历,Iterator: 每一个具体实现的数据集合,一般都需要提供相应的Iterator.相比于传统for循环,Iterator取缔了显式的遍历计数器.所以基于顺序存储集合的Iterator可以直接按位置访问数据. 而基于链式存储集合的Iterator,正常的实现,都是需要保存当前遍历的位…
集合 ArrayList 丑数: 能被3,5,7整除多次, ArrayList     list 接口             | - ArrayList             | - LinkedList     ArrayList 内部封装一个数组     用数组存放数据     默认初始容量是 10,     放满后会新建1.5倍的长度的新数组     之前数据复制放入新数组,之前数组释放     数组访问效率高,任意位置都是     但是增删数据效率可能低     创建对象      …
在编写java程序中,我们最常用的除了八种基本数据类型,String对象外还有一个集合类,在我们的的程序中到处充斥着集合类的身影!java中集合大家族的成员实在是太丰富了,有常用的ArrayList.HashMap.HashSet,也有不常用的Stack.Queue,有线程安全的Vector.HashTable,也有线程不安全的LinkedList.TreeMap等等! 上面的图展示了整个集合大家族的成员以及他们之间的关系.下面就上面的各个接口.基类做一些简单的介绍(主要介绍各个集合的特点.区别…