Java 中HashTable、HashMap、TreeMap三者区别,以及自定义对象是否相同比较,自定义排序等
/*
Map集合:该集合存储键值对。一对一对往里存。而且要保证键的唯一性。
Map
|--Hashtable:底层是哈希表数据结构,不可以存入null键null值。该集合是线程同步的。效率低。基本已废弃
|--HashMap:底层是哈希表数据结构,允许使用 null 值和 null 键,该集合是不同步的。将hashtable替代,.效率高,不保证顺序。
|--TreeMap:底层是二叉树数据结构。线程不同步。可以用于给map集合中的键进行排序。保证顺序
*/ import java.util.*; /**
* 学生类实现Comparable可比较接口
*/
class Student implements Comparable<Student> {
private String name;
private int age; Student(String name, int age) {
this.name = name;
this.age = age;
} /**
* 覆写接口中的compareTo方法跟equals覆写组合判断对象是否相同
*
* @param s
* @return
*/
@Override
public int compareTo(Student s) {
int num = Integer.valueOf(this.age).compareTo(s.age);
if (num == 0)
return this.name.compareTo(s.name);
return num;
} /**
* 覆写hashcode方法用于底层采用hash算法的容器
*
* @return
*/
@Override
public int hashCode() {
//用姓名和年龄组合值作为hashcode
return name.hashCode() + age * 34;
} /**
* 覆写equals方法实现自定义比较
*
* @param obj
* @return
*/
@Override
public boolean equals(Object obj) {
if (!(obj instanceof Student))
throw new ClassCastException("类型不匹配");
//强制转换类
Student s = (Student) obj;
//比较类中成员变量是否相同
return this.name.equals(s.name) && this.age == s.age;
} public String getName() {
return name;
} public int getAge() {
return age;
} public String toString() {
return name + "," + age;
}
} /**
* 比较器
*/
class StuNameComparator implements Comparator<Student> {
public int compare(Student s1, Student s2) {
int num = s1.getName().compareTo(s2.getName());
if (num == 0)
return Integer.valueOf(s1.getAge()).compareTo(s2.getAge());
return num;
}
} class Test2 {
public static void main(String[] args) {
HashMap<Student, String> hm = new HashMap<Student, String>(); hm.put(new Student("lisi1", 21), "beijing");
hm.put(new Student("lisi1", 21), "beijing"); //与上面相同不存
hm.put(new Student("lisi1", 21), "tianjin");
hm.put(new Student("lisi2", 22), "shanghai");
hm.put(new Student("lisi3", 23), "nanjing");
hm.put(new Student("lisi4", 24), "wuhan");
hm.put(new Student("lisi4", 24), "wuhan"); //与上面相同不存 System.out.println("-----------------第第一种取出方式 keySet, 迭代器-------------------------");
//第一种取出方式 keySet, 迭代器 Set<Student> keySet = hm.keySet(); Iterator<Student> it = keySet.iterator(); while (it.hasNext()) {
Student stu = it.next();
String addr = hm.get(stu);
System.out.println(stu + "___" + addr);
} System.out.println("-----------------第二种取出方式 entrySet, 迭代器-------------------------"); //第二种取出方式 entrySet, 迭代器
Set<Map.Entry<Student, String>> entrySet = hm.entrySet(); Iterator<Map.Entry<Student, String>> iter = entrySet.iterator(); while (iter.hasNext()) {
Map.Entry<Student, String> me = iter.next();
Student stu = me.getKey();
String addr = me.getValue();
System.out.println(stu + "___" + addr);
} System.out.println("---------------第三种取出方式 for循环方式---------------------------"); //第三种取出方式 for循环方式
for (Map.Entry<Student, String> entry : hm.entrySet()) {
System.out.println(entry.getKey() + "___" + entry.getValue());
} System.out.println("----------------TreeMap自定义排序,使用比较器--------------------------");
//TreeMap自定义排序,使用比较器
TreeMap<Student,String> tm = new TreeMap<Student,String>(new StuNameComparator());
tm.put(new Student("lisi1", 21), "beijing");
tm.put(new Student("lisi1", 21), "beijing"); //与上面相同不存
tm.put(new Student("lisi1", 21), "tianjin");
tm.put(new Student("lisi2", 22), "shanghai");
tm.put(new Student("lisi3", 23), "nanjing");
tm.put(new Student("lisi4", 24), "wuhan");
tm.put(new Student("lisi4", 24), "wuhan"); //与上面相同不存
for (Map.Entry<Student, String> entry : tm.entrySet()) {
System.out.println(entry.getKey() + "___" + entry.getValue());
} /**
* -----------------第第一种取出方式 keySet, 迭代器-------------------------
* lisi4,24___wuhan
* lisi2,22___shanghai
* lisi1,21___tianjin
* lisi3,23___nanjing
* -----------------第二种取出方式 entrySet, 迭代器-------------------------
* lisi4,24___wuhan
* lisi2,22___shanghai
* lisi1,21___tianjin
* lisi3,23___nanjing
* ---------------第三种取出方式 for循环方式---------------------------
* lisi4,24___wuhan
* lisi2,22___shanghai
* lisi1,21___tianjin
* lisi3,23___nanjing
* ----------------TreeMap自定义排序,使用比较器--------------------------
* lisi1,21___tianjin
* lisi2,22___shanghai
* lisi3,23___nanjing
* lisi4,24___wuhan
*/
}
}
Java 中HashTable、HashMap、TreeMap三者区别,以及自定义对象是否相同比较,自定义排序等的更多相关文章
- Hashtable,HashMap,TreeMap有什么区别?Vector,ArrayList,LinkedList有什么区别?int和Integer有什么区别?
接着上篇继续更新. /*请尊重作者劳动成果,转载请标明原文链接:*/ /*https://www.cnblogs.com/jpcflyer/p/10759447.html* / 题目一:Hashtab ...
- 沉淀再出发:java中的HashMap、ConcurrentHashMap和Hashtable的认识
沉淀再出发:java中的HashMap.ConcurrentHashMap和Hashtable的认识 一.前言 很多知识在学习或者使用了之后总是会忘记的,但是如果把这些只是背后的原理理解了,并且记忆下 ...
- Java中Set Map List 的区别
java中set map list的区别: 都是集合接口 简要说明 set --其中的值不允许重复,无序的数据结构 list --其中的值允许重复,因为其为有序的数据结构 map--成对的数据结构 ...
- Java中Comparable和Comparator接口区别分析
Java中Comparable和Comparator接口区别分析 来源:码农网 | 时间:2015-03-16 10:25:20 | 阅读数:8902 [导读] 本文要来详细分析一下Java中Comp ...
- Java中关于HashMap的元素遍历的顺序问题
Java中关于HashMap的元素遍历的顺序问题 今天在使用如下的方式遍历HashMap里面的元素时 1 for (Entry<String, String> entry : hashMa ...
- java中fail-fast 和 fail-safe的区别
java中fail-fast 和 fail-safe的区别 原文地址:http://javahungry.blogspot.com/2014/04/fail-fast-iterator-vs-fa ...
- [转]为什么Java中的HashMap默认加载因子是0.75
前几天在一个群里看到有人讨论hashmap中的加载因子为什么是默认0.75. HashMap源码中的加载因子 static final float DEFAULT_LOAD_FACTOR = 0.75 ...
- Java中的HashMap的工作原理是什么?
问答题23 /120 Java中的HashMap的工作原理是什么? 参考答案 Java中的HashMap是以键值对(key-value)的形式存储元素的.HashMap需要一个hash函数,它使用ha ...
- 关于Java中的HashMap的深浅拷贝的测试与几点思考
0.前言 工作忙起来后,许久不看算法,竟然DFA敏感词算法都要看好一阵才能理解...真是和三阶魔方还原手法一样,田园将芜,非常可惜啊. 在DFA算法中,第一步是需要理解它的数据结构,在此基础上,涉及到 ...
- 转:Java中abstract和interface的区别
转自:Java中abstract和interface的区别 abstract class和interface是Java语言中对于抽象类定义进行支持的两种机制,正是由于这两种机制的存在,才赋予了Java ...
随机推荐
- trie树(前缀树)详解——PHP代码实现
trie树常用于搜索提示.如当输入一个网址,可以自动搜索出可能的选择.当没有完全匹配的搜索结果,可以返回前缀最相似的可能. 一.Tire树的基本性质 根节点不包含字符,除根节点外每一个节点都只包含一个 ...
- android RecyclerView的Linear布局案例
1.先创建 activity_recycle_view.xml 和 activity_recycler_linear_item.xml 如下: <?xml version="1.0&q ...
- java设计模式--观察者模式和事件监听器模式
观察者模式 观察者模式又称为订阅—发布模式,在此模式中,一个目标对象管理所有相依于它的观察者对象,并且在它本身的状态改变时主动发出通知.这通常透过呼叫各观察者所提供的方法来实现.此种模式通常被用来事件 ...
- Python学习日记(十九) 模块导入
模块导入 当文件夹中有这样一个自定义的command模块 在它的内部写下下列代码: print('这个py文件被调用!') def fuc(): print('这个函数被调用!') 然后我们在comm ...
- fetch() without execute() [for Statement "SHOW VARIABLES LIKE 'wsrep_on'
增加栏位: pt-online-schema-change --user=root --password=a099e0 --alter "ADD COLUMN IS_MOBILE INT ...
- C++中string::find()函数和string::npos函数的使用
1. string::find()函数和string::npos函数的介绍 我们在学习C++的时候必不可少的使用到string类中的find()函数,它是一个查找函数,功能还是很强大的,但是此处我们不 ...
- STL详细介绍(更新中~~~)
目录 string string的常见构造函数 string与char *(或const char*)之间的转换 string 转化为const char* const char* 转化为string ...
- 04 Spring的依赖注入
依赖注入:Dependency Injection.它是 spring 框架核心 ioc 的具体实现. 我们的程序在编写时,通过控制反转,把对象的创建交给了 spring,但是代码中不可能出现没有依赖 ...
- 在PHP中使用CURL实现GET和POST请求的方法
1.CURL介绍 CURL是一个利用URL语法规定来传输文件和数据的工具.支持很多协议,如HTTP.FTP.TELNET等. 幸运的是PHP也支持CURL库.本文将介绍curl的一些高级特性,以及在P ...
- c语言中,如果将无符号数转换为有符号数
在使用ti的adc芯片ads1259时,芯片是24为数据格式保存的,其中最高位是符号位,因此可以理解为是有符号数据,但是在嵌入式系统中,没有直接24位的变量,因此使用32的无符号先保存24位的数据. ...