黑马程序员---哈希表存取操作原理
2013-08-09 18:22
246 查看
如何存?
下标是根据key的hash值算出来的。当我们向Hashtable中Add元素时,元素储存在Hashtable的数组里的下标是根据添加key的hash值算出来的(但因为hash值取模数组长度,所以肯定不会超过当前数组长度)
每个对象算出的Hashcode并不是唯一的,有可能出现多个对象的Hashcode相同
解决机制
再Hash一次
桶装模式,将两个相同的Hashcode的对象装入一个位置
当新增时,Hashtable里的容器数组已经满了,则以数组的两倍扩容
如何取?
当我们从Hashtable里取元素时(根据key来取),会根据key的hash值算出要取的元素的下标,并比较元素里的key和当前要找的key参数的hash值是否相等,同时还要比较两个key的引用是否一致,如果都满足,则确定找到要取的元素
下标是根据key的hash值算出来的。当我们向Hashtable中Add元素时,元素储存在Hashtable的数组里的下标是根据添加key的hash值算出来的(但因为hash值取模数组长度,所以肯定不会超过当前数组长度)
每个对象算出的Hashcode并不是唯一的,有可能出现多个对象的Hashcode相同
解决机制
再Hash一次
桶装模式,将两个相同的Hashcode的对象装入一个位置
当新增时,Hashtable里的容器数组已经满了,则以数组的两倍扩容
如何取?
当我们从Hashtable里取元素时(根据key来取),会根据key的hash值算出要取的元素的下标,并比较元素里的key和当前要找的key参数的hash值是否相等,同时还要比较两个key的引用是否一致,如果都满足,则确定找到要取的元素
相关文章推荐
- JAVA NIO缓冲区的存取操作原理及方法
- 黑马程序员_Java基础_IO流_字节流,字节流操作文件,缓冲区字节流,流的使用规律,异常记录原理
- SSH原理与运用(二):远程操作与端口转发
- 黑马程序员面试题高新技术之(JavaBean复杂操作,注解Annotation,泛型应用Generic)
- 黑马程序员_Java基础_IO流(字符流缓冲区和字节流相关操作以及相关操作技巧)
- SSH原理与运用(二):远程操作与端口转发
- 黑马程序员----用LinkedList模仿堆栈和队列原理
- 黑马程序员自学笔记————字符编码原理,以及开发中常见的问题的解决方法:
- 黑马程序员_java IO流及文件操作详解
- 黑马程序员—IO(一)流概述、字符流、字节流、流操作规律
- 黑马程序员-->10_字符串操作
- 分布式文件系统HDFS原理与操作
- Atitit.木马病毒的操作注册表原理 系统服务管理器 atiSysService
- Avro 序列化操作原理与应用
- C#中的文件的IO原理及操作
- Redis命令学习—Hash(哈希表)操作
- Linux内核原子操作 原理
- SSH原理与运用(二):远程操作与端口转发
- 黑马程序员————java中的递归原理
- 哈希表操作改进