`
momsbaby1986
  • 浏览: 33945 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

dubbo --- LRUCache简单实现

 
阅读更多
import java.util.LinkedHashMap;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class LRUCache<K, V> extends LinkedHashMap<K, V> {

	private static final long serialVersionUID = -5167631809472116969L;

	private static final float DEFAULT_LOAD_FACTOR = 0.75f;

	private static final int DEFAULT_MAX_CAPACITY = 1000;

	private volatile int maxCapacity;

	private final Lock lock = new ReentrantLock();

    public LRUCache() {
    	this(DEFAULT_MAX_CAPACITY);
    }

    public LRUCache(int maxCapacity) {
        super(16, DEFAULT_LOAD_FACTOR, true);
        this.maxCapacity = maxCapacity;
    }

    @Override
    protected boolean removeEldestEntry(java.util.Map.Entry<K, V> eldest) {
        return size() > maxCapacity;
    }

    @Override
    public boolean containsKey(Object key) {
        try {
            lock.lock();
            return super.containsKey(key);
        } finally {
            lock.unlock();
        }
    }

    @Override
    public V get(Object key) {
        try {
            lock.lock();
            return super.get(key);
        } finally {
            lock.unlock();
        }
    }

    @Override
    public V put(K key, V value) {
        try {
            lock.lock();
            return super.put(key, value);
        } finally {
            lock.unlock();
        }
    }

    @Override
    public V remove(Object key) {
        try {
            lock.lock();
            return super.remove(key);
        } finally {
            lock.unlock();
        }
    }

    @Override
    public int size() {
        try {
            lock.lock();
            return super.size();
        } finally {
            lock.unlock();
        }
    }

    @Override
    public void clear() {
        try {
            lock.lock();
            super.clear();
        } finally {
            lock.unlock();
        }
    }

	public int getMaxCapacity() {
		return maxCapacity;
	}

	public void setMaxCapacity(int maxCapacity) {
		this.maxCapacity = maxCapacity;
	}

}

 

利用LinkedHashMap扩展实现简单的LRUCache,主要两点:

1.重写removeEldestEntry方法,决定何时移除最旧条目

2.关键方法加锁,如put、get

 

 

说明:

加载因子:

 

如果哈希表中的元素放得太满,就必须进行rehashing(再哈希)。再哈希使哈希表元数增倍,
并将原有的对象重新导入新的哈希表元中,而原始的哈希表元被删除。
load factor(加载因子)决定何时要对哈希表进行再哈希。
在Java编程语言中,加载因子默认值为0.75,默认哈希表元为101

 

分享到:
评论

相关推荐

    dubbo-admin-2.5.4及dubbo-monitor-2.5.3 安装及配置

    本人实际测试过,这两个包可用。...2.修改dubbo-monitor中的conf目录中的dubbo.properties dubbo.registry.address 与 dubbo-admin中的配置一样 3.到dubbo-monitor中的bin目录下运行 start.sh脚本 ok

    dubbo-dubbo-2.7.3.rar

    dubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo-2.7.3.rardubbo源码dubbo-dubbo...

    dubbo-admin-2.5.4.war

    3. **服务提供者(Provider)**:在 Dubbo 中,服务提供者是指实现了特定服务接口,并对外提供服务的组件。开发者可以使用 Dubbo 提供的 API 或注解来声明和暴露服务。 4. **服务消费者(Consumer)**:服务消费者...

    dubbo-admin的下载

    【标题】"dubbo-admin的下载" 在分布式系统开发中,Dubbo是一个广泛使用的高性能Java RPC框架,由阿里巴巴开源。而dubbo-admin是Dubbo框架的一部分,它提供了一个管理控制台,允许开发者监控和管理服务的运行状态,...

    dubbo-demo-consumer、dubbo-demo-provider、dubbo-simple-monitor

    《Dubbo实战:消费者、提供者与简单监控》 Dubbo是阿里巴巴开源的一款高性能、轻量级的服务治理框架,广泛应用于分布式系统中的服务调用。本篇将详细讲解基于dubbo-demo-consumer、dubbo-demo-provider和dubbo-...

    incubator-dubbo-dubbo-2.5.8

    【标题】"incubator-dubbo-dubbo-2.5.8" 是一个基于Java的开源服务框架,由Apache孵化器项目提供。这个版本是Dubbo的2.5.8稳定版,它包含了Dubbo的核心服务治理功能以及一个专门的管理平台——dubbo-admin。 【描述...

    dubbo-admin包

    通过与Tomcat等Servlet容器的集成,用户可以快速部署和使用这个强大的工具,实现对Dubbo服务的可视化管理和监控。在微服务架构日益普及的今天,熟悉和掌握dubbo-admin的使用对于提升服务治理能力至关重要。

    dobbo源码dubbo-dubbo-2.7.3.rar

    dobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo-2.7.3.rardobbo源码dubbo-dubbo...

    incubator-dubbo-ops-master.rar

    《Apache Incubator Dubbo-OPS Master:深度解析与实践》 Apache Incubator Dubbo-OPS Master 是一套由Dubbo社区开发的管理工具,旨在为Dubbo服务提供全面的运营管理和监控支持。Dubbo,作为一款高性能、轻量级的...

    dubbo-admin-2.5.4.war后台管理

    《Dubbo Admin 2.5.4:高效管理与监控的利器》 在分布式系统中,服务治理扮演着至关重要的角色。Dubbo,作为阿里巴巴开源的一款高性能、轻量级的Java RPC框架,提供了丰富的服务治理功能。其中,`dubbo-admin`是...

    incubator-dubbo-dubbo-2.6.1

    1. **RPC框架**:Dubbo支持基于接口的透明远程调用,使得服务消费方无须关心服务提供方的具体实现。 2. **服务注册与发现**:Dubbo通过注册中心进行服务的注册和发现,服务提供方将服务信息注册到注册中心,服务消费...

    dubbo-monitor-simple-2.5.8-assembly.tar.gz

    `dubbo-monitor-simple`是Dubbo监控模块的一个简易实现,它基于Servlet,提供了一个Web UI,用于收集和展示Dubbo服务的运行数据。这个模块的核心在于`SimpleMonitor`,它实现了`MonitorService`接口,负责接收和处理...

    dubbo-admin-2.5.5.war

    dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!dubbo-admin打包后的文件,扔到tomcat里就能跑起来!

    jmeter-plugins-dubbo-2.7.8-jar-with-dependencies.jar

    jmeter的dubbo插件,jmeter-plugins-dubbo-2.7.8-jar-with-dependencies.jar,适用于JMeter5.4.1版本,将解压后的文件jmeter-plugins-dubbo-2.7.8-jar-with-dependencies放在Jmeter安装目录下的\lib\ext文件夹中,...

    dubbo-admin包,dubbo-admin.war,基于github中dubbo源码打包,亲测可用。

    【标题】"dubbo-admin包"是Dubbo项目的一个重要组成部分,主要提供了管理控制台的功能。这个特定的版本,"dubbo-admin.war",是根据GitHub上的Dubbo源代码编译并打包而成的,确保了其与最新的开发成果同步,并且已经...

    dubbo-admin dubbo-monitor.zip 2.8.4可用

    1. dubbo-monitor-simple-2.8.4-assembly.tar.gz:这是一个包含Dubbo监控简单实现的归档文件,版本为2.8.4。它通常包含了启动监控服务所需的所有依赖,用户可以通过解压并运行其中的脚本来启动监控服务。 2. dubbo-...

    dubbo-monitor-simple-2.6.1.tgz

    dubbo官方自带了dubbo-admin及dubbo-simple/dubbo-monitor-simple二个子项目用于服务治理及服务监控。 dubbo-monitor-simple是Alibaba的开源项目,用于监控在dubbo框架下接口暴露,注册情况,也可以看接口的调用...

    dubbo-admin-2.6.0下载

    1. **Dubbo服务治理**:Dubbo提供了包括服务注册与发现、负载均衡、熔断机制、服务降级、服务限流、服务鉴权等一系列服务治理功能,帮助开发者实现微服务架构中的服务治理。 2. **Dubbo-admin作用**:dubbo-admin是...

    jmeter-plugins-dubbo-2.7.1-jar-with-dependencies

    《JMeter Plugins for Dubbo压力测试详解》 在IT行业中,系统压力测试是评估软件性能不可或缺的一环。本文将深入探讨“jmeter-plugins-dubbo-2.7.1-jar-with-dependencies”这一系统压测工具包,它专门针对基于Java...

Global site tag (gtag.js) - Google Analytics