android(java) HashMap详解

1. Java中HashMap的常用操作

2. java提高篇(二三)-----HashMap

3. Android内存优化(使用SparseArray和ArrayMap代替HashMap)

4. 浅谈Java中的hashcode方法


简记

1. 当在hashmap中put的key在之前已经存过,则不会重复存储,会覆盖之前key对应的value

2. 遍历hashmap的两种方式:haspmap.entrySet().iterator(), hashmap.keySet().iterator()

3. HashMap是一种支持快速存取,无序的数据结构:数组+链表(单向链表)     //LinkedHashMap是数组+链表(双向链表)

4. 处理hash冲突的方法有以下几种:

   开放地址法

   再哈希法

   链地址法

   建立公共溢出区

5. 当HashMap中的数据量>容量*加载因子,而HashMap中默认的加载因子是0.75,HashMap的空间将会扩大,而且扩大后新的空间一定是原来的2倍

6. 当向集合中插入对象时,如何判别在集合中是否已经存在该对象了?(注意:集合中不允许重复的元素存在)

   也许大多数人都会想到调用equals方法来逐个进行比较,这个方法确实可行。但是如果集合中已经存在一万条数据或者更多的数据,如果采用equals方法去逐一比较,效率必然是一个问题。此时hashCode方法的作用就体现出来了,当集合要添加新的对象时,先调用这个对象的hashCode方法,得到对应的hashcode值,实际上在HashMap的具体实现中会用一个table保存已经存进去的对象的hashcode值,如果table中没有该hashcode值,它就可以直接存进去,不用再进行任何比较了;如果存在该hashcode值, 就调用它的equals方法与新元素进行比较,相同的话就不存了,不相同就散列其它的地址,

6. 我们知道在Android的缓存机制中无论是用第三方的还是我们自己写的,一般都会用到LruCache或者LinkedHashMap类,而LruCache里面封装的又是LinkedHashMap,LinkedHashMap又是HashMap的子类

HashMap结构图

android(java) HashMap详解_第1张图片



你可能感兴趣的:(Android)