JAVA 映射HashMap和HashTable的区别和实用
/*
* @author Mr liu
*
* 基本格式:HashMap<key,vaule>
* 面试题
* HashMap和HashTable的区别:
* 1、HashMap在HashTable的基础上去掉了contains的方法,比HashTable多了containsvalues和containkey的方法
* 2、HashMap线程不安全(异步,效率高),HashTable线程安全(同步,效率比不上HashMap),其实用CurrentHashMap是最好的选择。(即同步了HashTable的安全,也综合了HashMap的效率)
* 3、HashMap允许空键值,而HashTable不允许
*/
public class Mapping {
/**
* @param args
*/
public static void main(String[] args) {
HashMap<StudentD,String> hm = new HashMap<StudentD,String>();
hm.put(new StudentD("xiaobai",23),"shanghai");
hm.put(new StudentD("wanghei",20),"beijing");
hm.put(new StudentD("lisi",28),"shenzhen");
hm.put(new StudentD("lisi",28),"shenzhen");
//collenction:集合的接口 主要继承的接口是set和list。通过集合存储hm的value值
Collection<String> collect=hm.values();
//st就是hashmap的key值,key值是不重复且唯一的
for (StudentD st : hm.keySet()) {
for (String string : collect) {
if(string.equals("shenzhen"))
System.out.println(st+"---"+hm.get(st)+"value:"+string+"------st:"+st.name);
}
}
}
}
class StudentD{
String name;
int age;
public StudentD(String name,int age){
this.name=name;
this.age=age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "StudentD [name=" + name + ", age=" + age + "]";
}
}
输出结果:
总结:HashTable和HashMap的实现原理几乎一样,差别无非是,映射对于自己开发都是比较方便的,告别了以前的for语句循环。大大提高了代码的高效率。可能有更多区别和大佬们的理解不一,希望各位大佬能多多评论,我也好多做些笔记。