java LinkedHashMap示例

本文深入探讨了Java中LinkedHashMap的工作原理,特别是在访问顺序和空间管理方面的特性。通过具体示例,展示了如何利用LinkedHashMap的特性来实现一个自动释放最不常访问对象的资源池。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.LinkedHashMap;
import java.util.Map;

/**
 * @author yuan
 * @date 2019/1/24
 * LinkedHashMap通常提供的是遍历顺序符合插入顺序,它的实现是
 * 通过为条目(键值对)维护一个双向链表。注意,通过特定构造函 数,我们可以创建反映访问顺序的实例,所谓的put、get、compute 等,都算作“访问”。
 * 这种行为适用于一些特定应用场景,例如,我们构建一个空间占用敏感 的资源池,希望可以自动将最不常被访问的对象释放掉,这就可以利用 LinkedHashMap提供的机制来实现
 */
public class LinkedHashMapSample {
    public static void main(String[] args) {
        LinkedHashMap<String, Integer> map = new LinkedHashMap<>() {
            @Override
            protected boolean removeEldestEntry(Map.Entry<String, Integer> eldest) {
                return size() > 3;
            }
        };

        map.put("3", 3);
        map.put("1", 1);
        map.put("6", 6);
        map.forEach((k, v) -> System.out.println(k + ":" + v));

        System.out.println();

        map.get("1");
        map.get("1");
        map.get("6");

        map.forEach((k, v) -> System.out.println(k + ":" + v));

        System.out.println();

        map.put("4", 4);
        // 触发删除,3被删除
        map.forEach((k, v) -> System.out.println(k + ":" + v));

    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值