HashMap源码阅读笔记
来源:互联网 发布:淘宝商品不含区间价格 编辑:程序博客网 时间:2024/05/18 17:41
1.put方法
publicV put(K key,V value) {if (table== EMPTY_TABLE) {inflateTable(threshold);//如果map为空,执行inflateTable扩充}if (key== null)returnputForNullKey(value);inthash = hash(key);//使用hash算法获取key的hash值inti =indexFor(hash,table.length);for (Entry<K,V>e = table[i]; e!= null; e= e.next) {//遍历map集合中已存在的元素Objectk; //对比新增元素key的hash值与map中已存在的hash值,如果不同直接添加元素,如果相同则用新value替换旧value,//并return旧value 。//通过hash算法,大大减少了对比运算次数,提高效率if (e.hash== hash && ((k =e.key)== key || key.equals(k))) {VoldValue = e.value;e.value= value;e.recordAccess(this);return oldValue;}}modCount++;addEntry(hash, key, value, i);//添加元素returnnull;}
阅读全文
0 0
- HashMap源码阅读笔记
- HashMap源码阅读笔记
- HashMap源码阅读笔记
- HashMap源码阅读笔记
- 每日一得--hashmap源码阅读笔记
- java集合源码阅读笔记-HashMap
- JAVA8 hashmap源码阅读笔记(红黑树链表)
- hashmap 源码阅读
- HashMap源码阅读
- HashMap源码阅读
- HashMap源码阅读
- HashMap源码阅读
- Java源码阅读-HashMap
- HashMap源码阅读
- HashMap源码阅读
- HashMap源码阅读
- HashMap 1.7源码阅读
- 阅读HashMap源码
- 虚拟机(VMware)之在Ubuntu下安装VMware Tools
- spirngboot之Sqlite数据库
- REST架构风格
- POJ1189钉子和小球,人人为我 我为人人 longlong 位操作
- HTML打字机和字体发光效果
- HashMap源码阅读笔记
- 配置ubuntu服务器
- Object有哪些公用方法
- # Software-eng lab 6
- 东土科技牵手奥维奥,实现企业人力资源战略部署
- maven 默认JDK设置
- 详细Windows10下Myeclipse 2017安装图解教程
- 操作系统面试持续总结中。。。
- Macaca Inspector启动命令