import java.util.Collection;
import java.util.HashMap;
import java.util.Map.Entry;
import java.util.Set;
/**
*
*hashmap调用默认构造方法会产生一个底层长度为16的entry数组
*int hash=hash (key.hashcode());
*首先调用key的hashcode方法来得到一个整数---哈希码;
*把哈希码作为参数传入到hash函数中来进行运算--散列运算--得到了一个整型--散列值
*int i=indexfor(hash ,table .length);
*吧散列值和数组的长度进行运算,最终得到entry对象要存放到数组的位置 (下标)
*hashmap内部的结构是数组链表结构
*因为不同的key有可能算出来是相同的散列值根据散列值计算出存放到数组的下标会冲突
*
*
*/
public class HashMapDemo1 {
@SuppressWarnings("unused")
public static void main(String[] args) {
HashMap<String , String > map=new HashMap<String ,String >();
map.put("zhangsan", "张三");
map.put("zhangsan", "张da");//键值一样时将被下面的覆盖
map.put("lisi", " 李四");
map.put("rose", "玫瑰");
map.put("wangwu", "王五");
System.out.println(map);
//获取map中的所有键
Set<String> keys=map.keySet();
for (String key : keys) {
System.out.println(keys);
}
//获取map中的所有值
Collection<String> values=map.values();
for (String value : values) {//使用增强for循环进行遍历输出
System.out.println(value);
}
//得到key的同时得到key所对应的值
Set<String> key1=map.keySet();
for (String key : keys) {
System.out.println(keys+">.."+map.get(values));
}
System.out.println(map.size());//输出map的长度
System.out.println(map.isEmpty());//判断是否为空
/*当我们调用put(key,value)方法的时候,首先会把key和value封装到entry这个静态内部类对象中
* 把entry对象再添加到数组中,所以我们想获取map中的所有键值对我们只要获取数组中的所有
* entry对象,接下来调用entry对象中的getkey和getvalue方法就能获取键值对*/
//获取键的同时获取值
Set<Entry<String, String>> entrySet=map.entrySet();
for (Entry<String, String> entry : entrySet) {
System.out.println(entry.getKey()+">>>>"+entry.getValue());
}
}
}