Java - Map
2016-06-23 10:15
441 查看
遍历Map的方法
1、Entry
for (Map.Entry<String, String> entry : map.entrySet()) {
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
2、Iterator
Iterator iterator = map.entrySet().iterator();
while (iterator .hasNext()) {
Map.Entry<String, String> entry = iterator .next();
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
3、keySet()
for (String key : map.keySet()) {
System.out.println("key= "+ key + " and value= " + map.get(key));
}
HashMap
put(key, value)
1、处理key为null的情况
if (key == null)
return putForNullKey(value);
2、计算key的哈希值
int hash = hash(key);
3、找到该哈希码对应的存储位置
int i = indexFor(hash, table.length);
4、遍历该存储位置的单链表,如果已存在key,则覆盖entry,否则添加entry。
for (Entry<K,V> e = table[i]; e != null; e = e.next) {
Object k;
// key存在则新entry覆盖旧entry
if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
V oldValue = e.value;
e.value = value;
e.recordAccess(this);
return oldValue;
}
}
// key不存在则添加entry
modCount++;
addEntry(hash, key, value, i);
HashMap和HashSet
相同点
HashMap的K唯一,HashSet的元素唯一。
区别
HashMap实现了Map接口
HashSet实现了Set接口
HashMap储存键值对,而HashSet仅储对象。
1、Entry
for (Map.Entry<String, String> entry : map.entrySet()) {
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
2、Iterator
Iterator iterator = map.entrySet().iterator();
while (iterator .hasNext()) {
Map.Entry<String, String> entry = iterator .next();
System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
}
3、keySet()
for (String key : map.keySet()) {
System.out.println("key= "+ key + " and value= " + map.get(key));
}
HashMap
put(key, value)
1、处理key为null的情况
if (key == null)
return putForNullKey(value);
2、计算key的哈希值
int hash = hash(key);
3、找到该哈希码对应的存储位置
int i = indexFor(hash, table.length);
4、遍历该存储位置的单链表,如果已存在key,则覆盖entry,否则添加entry。
for (Entry<K,V> e = table[i]; e != null; e = e.next) {
Object k;
// key存在则新entry覆盖旧entry
if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
V oldValue = e.value;
e.value = value;
e.recordAccess(this);
return oldValue;
}
}
// key不存在则添加entry
modCount++;
addEntry(hash, key, value, i);
HashMap和HashSet
相同点
HashMap的K唯一,HashSet的元素唯一。
区别
HashMap实现了Map接口
HashSet实现了Set接口
HashMap储存键值对,而HashSet仅储对象。
相关文章推荐
- java 操作给定的二叉树,将其变换为源二叉树的镜像。
- springmvc Ajax批量删除
- Java多线程系列--“基础篇”04之 synchronized
- Android开发中eclipse DDMS的devices里面看不到连接的手机
- JAVA中获取工程路径的方法
- Eclipse+pydev解决中文显示和注释问题的方法大全
- Java enum的用法详解
- java实现分组
- Java 序列化Serializable详解(转载)
- springmvc注解开发-springmvc参数绑定过程
- SpringMVC原理浅析
- The method of type must override a superclass method解决方式
- 使用监听器实现Java Web的定时执行
- 《Java小游戏实现》:坦克大战(续四)
- JAVA中获取当前系统时间
- spring MVC配置详解
- 解决java连接SQLSERVER数据库之驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:Could not generate DH keypair”。
- eclipse 中jar包管理
- springmvc+spring jdbc+velocity入门教程及其代码实例
- spring boot注解 --@EnableAsync 异步调用