HashMap集合是一个比较特殊的集合,它集成了ArrayList和LinkedList的特点。ArrayList的优点是索引快,LinkedList的优点是插入或删除方便,而HashMap则是由他们两个的优点集成而来。
HashMap是由一个数组和链表组成,用数组来保存链表的首地址,从而来达到他们两个的优点。HashMap由键和值组成,其中键是唯一的,也就是键不可重复,值则可以重复,如果键重复了则会覆盖之前的数据。判断键的hashCode值是否相同,再判断两元素的equals方法是否为true,如果是自定义类,则要重写hashCode和equals方法。
public class demo {
public static void main(String[] args) {
//function();
function_2();
}
public static void function(){
/**
* @author admin
* 使用多态来引用子类对象
* map.keySet()这个方法会返回map中的key的set集合
*/
Map map = new HashMap<String,String>();
map.put("123", "abc");
map.put("234", "abc");
map.put("345", "abc");
System.out.println(map);
Iterator mapIt = map.keySet().iterator();
while(mapIt.hasNext()){
String key = (String) mapIt.next();
String value = (String) map.get(key);
System.out.println(key+"---"+value);
}
System.out.println("-----------------------");
}
public static void function_1(){
/**
* @author admin
* 使用map.entrySet()方法获得Key-value的关系
*/
Map map = new HashMap<String,String>();
map.put("123", "abc");
map.put("234", "abc");
map.put("345", "abc");
Iterator It = map.entrySet().iterator();
while(It.hasNext()){
Map.Entry entry = (Map.Entry) It.next();
String key = (String) entry.getKey();
String value = (String) entry.getValue();
System.out.println(key+"---"+value);
}
}
public static void function_2(){
Map map = new HashMap<String,String>();
map.put("123", "abc");
map.put("234", "abc");
map.put("345", "abc");
map.put("123", "111");
for(Object i : map.keySet()){
System.out.println((String)i+"..."+ (String)map.get(i));
}
}
}