按照插入顺序排序的LinkedHashMap

LinkedHashMap可以做到按照用户放入集合的顺序取出集合中的元素,但是⚠️HashMap不能做到

LinkedHashMap介绍:

LinkedHashMap继承于HashMap,其底层实现和HashMap一致,都用哈希表实现,区别是LinkedHashMap还使用了一个双向链表实现顺序存取所以LinkedHashMap是有序的,这个双向链表的实现依赖于Entry这个内部类,这个Entry内部类在集合中非常常见。LinkedHashMap允许存储null值,基本的和HashMap一致,通过键找到值,键不可以重复,值可以重复。

在删除和增加时,都在修改前面的引用和后面的引用。
在这里插入图片描述
在HashMap中只是利用了哈希表,而LinkedHashMap中还用到了链表记录顺序,在LinkedHashMap中并没有put方法,而是利用了HashMap中的put方法,但是重写了put方法中调用的的addEntry()方法.
在这里插入图片描述
在这里插入图片描述
通过上面方法的分析,可以看出在添加节点的时候(由于是双向链表)都会在尾部进行添加

TreeMap的顺序是自然顺序(如整数从小到大),也可以指定比较函数,但不是插入的顺序

参考

LinkedHashMap是Java中的一个集合类,它继承自HashMap,并且使用双向链表来维护元素的插入顺序或者访问顺序。因此,LinkedHashMap可以实现按照插入顺序或者访问顺序进行排序。 要使用LinkedHashMap进行排序,可以通过设置accessOrder参数来指定排序方式。当accessOrder为true时,LinkedHashMap会按照访问顺序进行排序;当accessOrder为false时,LinkedHashMap会按照插入顺序进行排序。 下面是一个示例代码,演示了如何使用LinkedHashMap进行排序: ```java import java.util.LinkedHashMap; import java.util.Map; public class LinkedHashMapSortExample { public static void main(String[] args) { // 创建一个LinkedHashMap对象 LinkedHashMap<String, Integer> map = new LinkedHashMap<>(); // 添加元素到LinkedHashMap map.put("apple", 10); map.put("banana", 5); map.put("orange", 8); map.put("grape", 3); // 打印原始的顺序 System.out.println("原始顺序:"); for (Map.Entry<String, Integer> entry : map.entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue()); } // 按照访问顺序排序 map = new LinkedHashMap<>(16, 0.75f, true); map.put("apple", 10); map.put("banana", 5); map.put("orange", 8); map.put("grape", 3); // 打印按照访问顺序排序后的结果 System.out.println("按照访问顺序排序后:"); for (Map.Entry<String, Integer> entry : map.entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue()); } // 按照插入顺序排序 map = new LinkedHashMap<>(16, 0.75f, false); map.put("apple", 10); map.put("banana", 5); map.put("orange", 8); map.put("grape", 3); // 打印按照插入顺序排序后的结果 System.out.println("按照插入顺序排序后:"); for (Map.Entry<String, Integer> entry : map.entrySet()) { System.out.println(entry.getKey() + ": " + entry.getValue()); } } } ``` 这段代码首先创建了一个LinkedHashMap对象,并添加了一些元素。然后,通过设置accessOrder参数为true,实现了按照访问顺序排序;通过设置accessOrder参数为false,实现了按照插入顺序排序。最后,通过遍历LinkedHashMap的entrySet,打印出排序后的结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值