Java TreeMap使用方法
1、使用默认的TreeMap 构造函数,其中key值需要有比较规则。
2、使用默认的TreeMap 构造函数,Key中添加自定义类型,自定义类型必须继承Comparator。
3、使用比较器类来来实现排序,自定义类型不用来继承Comparator
试例代码:
public class Demo {
public static void main(String[] args) {
//1、使用默认的TreeMap 构造函数,其中key值需要有比较规则
TreeMap<Integer, String> map =new TreeMap<>();
map.put(new Integer(2), "BB");
map.put(new Integer(1), "AA");
map.put(new Integer(5), "EE");
map.put(new Integer(3), "CC");
map.put(new Integer(4), "DD");
map.put(new Integer(2), "AA"); //验证重复key是否能够插入
//使用遍历EntrySet方式
for(Entry<Integer, String> entry:map.entrySet()){
System.out.println("Key:"+entry.getKey()+ " --- value:"+entry.getValue());
}
//2、使用默认的TreeMap 构造函数,Key中添加自定义类型,自定义类型必须继承Comparator
System.out.println("-------------------2、使用默认的TreeMap 构造函数,Key中添加自定义类型,自定义类型必须继承Comparator-----------------------");
TreeMap<person,String> mapPer=new TreeMap<>();
mapPer.put(new person("张三",22), "6K");
mapPer.put(new person("老王",35), "29K");
mapPer.put(new person("小张",31), "11K");
for(Entry<person, String> entry:mapPer.entrySet()){
System.out.println("Key:"+entry.getKey()+ " --- value:"+entry.getValue());
}
//3、使用比较器类来来实现排序,自定义类型不用来继承Comparator
System.out.println("-------------------3、使用比较器类来来实现排序,自定义类型不用来继承Comparator-----------------------");
TreeMap<Book,String> mapBook =new TreeMap<>(new BookComparator());
mapBook.put(new Book("流浪地球",60),"200页");
mapBook.put(new Book("三体",100),"400页");
mapBook.put(new Book("大秦帝国",180),"900页");
for(Entry<Book, String> entry:mapBook.entrySet()){
System.out.println("Key:"+entry.getKey()+ " --- value:"+entry.getValue());
}
} }
//自定义person类
class person implements Comparable<person> {
String name; int age;
public person(String name,int age) {
this.name=name;
this.age=age; }
@Override
public String toString() {
return "姓名:"+this.name +" 年龄:" +this.age;
}
@Override
public int compareTo(person o) {
if(o.age>this.age) {
return 1;
} else if(o.age<this.age) {
return -1;
}
return 0;
} }
//自定义book类
class Book {
String name;
double price;
public Book(String name,double price) {
this.name=name;
this.price=price; }
@Override
public String toString() {
return "书名:"+this.name+" 价格:"+this.price;
} }
//book比较器类
class BookComparator implements Comparator<Book>{
@Override
public int compare(Book o1, Book o2) {
if(o1.price>o2.price) {
return 1;
} else if(o1.price<o2.price) {
return -1;
}
return 0;
} }
Java TreeMap使用方法的更多相关文章
- Java - TreeMap源码解析 + 红黑树
Java提高篇(二七)-----TreeMap TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap ...
- java TreeMap 源代码分析 平衡二叉树
TreeMap 的实现就是红黑树数据结构,也就说是一棵自平衡的排序二叉树,这样就可以保证当需要快速检索指定节点. TreeSet 和 TreeMap 的关系 为了让大家了解 TreeMap 和 Tre ...
- Java TreeMap 和 LinkedHashMap【笔记】
Java TreeMap 和 LinkedHashMap[笔记] TreeMap TreeMap基本结构 TreeMap 底层的数据结构就是红黑树,和 HashMap 的红黑树结构一样 与HashMa ...
- oracle调用JAVA类的方法
导入jar包 在oracle中导入需要的jar包,我们把编辑好的java类打成jar包,直接在oarcle里面写简单的调用就可以了, 1.操作系统需要拥有支持loadjava命令的jdk. 2.加 ...
- Java中的方法应用
一.如何定义java中的方法 所谓方法,就是用来解决一类问题的代码的有序组合,是一个功能模块. 语法: 1. 访问修饰符:方法允许被访问的权限范围, 可以是 public.protected.priv ...
- Java Runtime.availableProcessors()方法
Java Runtime.availableProcessors()方法用法实例教程. 描述 java.lang.Runtime.availableProcessors() 方法返回到Java虚拟 ...
- paip.java OutOfMemoryError 解决方法o33
paip.java OutOfMemoryError 解决方法o33 java.lang.OutOfMemoryError: Requested # java.lang.OutOfMemoryErro ...
- Java读写文件方法总结
Java读写文件方法总结 Java的读写文件方法在工作中相信有很多的用处的,本人在之前包括现在都在使用Java的读写文件方法来处理数据方面的输入输出,确实很方便.奈何我的记性实在是叫人着急,很多时候既 ...
- java调用本地方法的时候报错 could not find the main class:xx.program will exit
如图所示,当在java调用本地方法的时候报错 我的解决办法是把dll文件放到System.out.println(System.getProperty("java.library.path& ...
随机推荐
- ubuntu下使用APT安装和卸载MySQL5.7
安装方式一: 向系统的软件仓库中列表中添加MySQL APT 仓库 去http://dev.mysql.com/downloads/repo/apt/.下载MySQL APT repository ...
- springboot +fastdfs 上传文件到到云服务器
fastdfs在云服务器的搭建和配置:https://blog.csdn.net/qq_41592652/article/details/104006289 springboot结构如下: appli ...
- python 作用域,global与nonlocal的区别
在Python中并不是所有的语句块中都会产生作用域.只有当变量在Module(模块).Class(类).def(函数)中定义的时候,才会有作用域的概念. 如果在函数中要对全局变量做改变可以使用glob ...
- dp-LCS(递归输出最短合串)
Problem Description The company "21st Century Fruits" has specialized in creating new sort ...
- 蒙蔽的FormBody
作为一个不算新人的新人,今天看到 了FormBody这个绿色字体,之前没有怎么注意过, 好了 ,发现了一篇文章,记录下. 这篇文章总结下来就是: 在前端穿过的数据是Json格式(当我们设置Conten ...
- Linux下安装Ant
前言 Apache Ant 是一个构建工具,可以将软件编译.测试.部署等步骤联系在一起完成自动化工作,比如可以利用Ant来执行Jmeter的 jmx 脚本,生成了 jtl 测试结果文件,接着再利用An ...
- QT 获取当前毫秒级时间缀
long long currentTime = QDateTime::currentDateTime().toMSecsSinceEpoch();
- EditPlus 添加 打开文件所在文件夹 功能
添加自定义工具: Tools -> Configure User Tools... -> Add Tool >> Menu Text: 打开所在的文件夹 Command: ex ...
- python的数据类型之列表list
列表是最常用的Python数据类型,它可以作为一个方括号内的逗号分隔值出现.例如: stus = ["zhangsan","lisi","wangwu ...
- PKU-3580 SuperMemo(Splay模板题)
SuperMemo 题目链接 Your friend, Jackson is invited to a TV show called SuperMemo in which the participan ...