如何创建Map集合?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何创建Map集合?相关的知识,希望对你有一定的参考价值。
参考技术A Java 为数据结构中的映射定义了一个接口 java.util.Map,它有三个实现类: HashMap、 HashTable 和 TreeMap。
由于接口中的方法都没有实现,因此,不能直接使用 new 来实例化一个接口,因为 new 只能用来实例化非抽象的类。
一种正确的写法为 Map<String,String> m = new HashMap<String,String>() ,把实例化 HashMap 对象的实例赋值给 Map 接口变量 m。
Map集合之TreeMap
参考技术A TreeMap: 键不允许重复 底层是树的结构 可排序
TreeMap 如果将自定义类放在 key的位置 ,那这个类必须实现 自然排序或者 定制排序,否则报 ClassCastException
如何实现排序? 两种方式:
1 自然排序:
1> 创建需要排序的类 实现 Comparable <需要排序的类型>
2> 重写 compareTo 返回值如果返回0 证明两个对象相同,则不能存入集合
如果返回 1 -1 升序 降序
调用者比参数大 返回1 就是升序
调用者比参数小 返回1 就是降序
允许出现 第一条件...第二条件...
3> 创建TreeSet集合 将类放入 TreeSet集合的泛型中
2 定制排序:
1> 创建需要排序的类
2> 创建比较器的类 实现 Comparator <需要排序的类>
3> 重写 compare方法
参数 o1 类似于 compareTo方法中的this 也就是调用者
参数 o2 类似于 compareTo方法中的参数
4> 创建TreeSet集合 泛型< 需要排序的类> 构造方法中 必须传递 比较器对象
举个例子
自然排序
Text.java
以上是关于如何创建Map集合?的主要内容,如果未能解决你的问题,请参考以下文章
Kotlin集合操作 ⑤ ( Map 集合 | 获取 Map 值 | Map 遍历 | 可变 Map 集合 )