java延遲map, 自定義延遲map, 過期清理map,map能力擴展。如何設置map數據過期,改造map適配數據過期

1. 功能:

??????????? map 線程安全,能夠對存入的數據設置過期,或者自定義刪除

2. aliyun代碼看到的一個對象正好符合上述需求

??? 出處是aliyun sdk core jar包的一個類。感興趣可以去下載下jar查看

下面是源碼:

package com.aliyuncs.policy.cache;import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.Future;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import org.apache.commons.lang3.concurrent.BasicThreadFactory;public class ThrottlingPool {private static final Map<String, Entity> map = new ConcurrentHashMap();private static final ScheduledExecutorService executor = new ScheduledThreadPoolExecutor(1, (new BasicThreadFactory.Builder()).namingPattern("throttling-pool-%d").daemon(true).build());public ThrottlingPool() {}public static synchronized void put(String key, Object data) {put(key, data, -1);}public static synchronized void put(final String key, Object data, int expire) {remove(key);if (data != null) {if (expire >= 0) {Future future = executor.schedule(new Runnable() {public void run() {synchronized(ThrottlingPool.class) {ThrottlingPool.map.remove(key);}}}, (long)expire, TimeUnit.MILLISECONDS);map.put(key, new Entity(data, expire, future));} else {map.put(key, new Entity(data, expire, (Future)null));}}}public static synchronized Object get(String key) {Entity entity = (Entity)map.get(key);return entity != null ? entity.getValue() : null;}public static synchronized <T> T get(String key, Class<T> clazz) {return (T)clazz.cast(get(key));}public static synchronized int getExpire(String key) {Entity entity = (Entity)map.get(key);return entity != null ? entity.getExpire() : 0;}public static synchronized Object remove(String key) {Entity entity = (Entity)map.remove(key);if (entity == null) {return null;} else {Future future = entity.getFuture();if (future != null) {future.cancel(true);}return entity.getValue();}}public static synchronized int size() {return map.size();}public static synchronized void clear() {for(Entity entity : map.values()) {if (entity != null) {Future future = entity.getFuture();if (future != null) {future.cancel(true);}}}map.clear();}public static synchronized Map<String, Entity> getPool() {return map;}private static class Entity {private Object value;private int expire;private Future future;public Entity(Object value, int expire, Future future) {this.value = value;this.expire = expire;this.future = future;}public Object getValue() {return this.value;}public int getExpire() {return this.expire;}public Future getFuture() {return this.future;}}
}

2. 但是有個問題,如果數據量大,且都設置有過期時間,容易過期不及時!單線程處理不過來

3. 下面代碼采用延遲隊列一版:

import java.util.concurrent.*;public class ThrottlingPool {private static final ConcurrentHashMap<String, Object> map = new ConcurrentHashMap<>();private static final DelayQueue<DelayedCacheEntry> delayQueue = new DelayQueue<>();private static final ExecutorService executor = Executors.newSingleThreadExecutor(r -> {Thread t = new Thread(r);t.setDaemon(true);return t;});public static void put(String key, Object data, long expireMs) {long expirationTime = System.currentTimeMillis() + expireMs;delayQueue.removeIf(entry -> entry.getKey().equals(key));map.put(key, data);delayQueue.offer(new DelayedCacheEntry(key, expirationTime));}public static Object get(String key) {return map.get(key);}public static void remove(String key) {map.remove(key);}public static int size() {return map.size();}// 啟動一個后臺線程處理過期任務static {executor.execute(() -> {while (!Thread.currentThread().isInterrupted()) {try {DelayedCacheEntry entry = delayQueue.take();
//                    synchronized (ThrottlingPool.class) {map.remove(entry.getKey());
//                    }} catch (InterruptedException ex) {ex.printStackTrace();Thread.currentThread().interrupt();break;}}});// 鉤子Runtime.getRuntime().addShutdownHook(new Thread(() -> {executor.shutdown();}));
//        Thread cleanupThread = new Thread(() -> {
//            while (true) {
//                try {
//                    DelayedCacheEntry entry = delayQueue.take();
//                    synchronized (ThrottlingPool.class) {
//                        map.remove(entry.getKey());
//                    }
//                } catch (InterruptedException e) {
//                    Thread.currentThread().interrupt();
//                    break;
//                }
//            }
//        });
//        cleanupThread.setDaemon(true);
//        cleanupThread.start();}private static class DelayedCacheEntry implements Delayed {private final String key;private final long expirationTime;public DelayedCacheEntry(String key, long expirationTime) {this.key = key;this.expirationTime = expirationTime;}@Overridepublic long getDelay(TimeUnit unit) {long diff = expirationTime - System.currentTimeMillis();return unit.convert(diff, TimeUnit.MILLISECONDS);}@Overridepublic int compareTo(Delayed o) {return Long.compare(this.expirationTime, ((DelayedCacheEntry) o).expirationTime);}public String getKey() {return key;}}}

4.本人水平有限,如有問題,歡迎指正

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/902668.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/902668.shtml
英文地址,請注明出處:http://en.pswp.cn/news/902668.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

國芯思辰|可編程線性霍爾傳感器AH820替換HAL825用于汽車渦輪增壓

渦輪增壓技術是提高發動機的進氣能力的技術&#xff0c;霍爾傳感器可以達到監測渦輪轉速的作用。在渦輪增壓器的軸上安裝一個永磁體&#xff0c;當渦輪旋轉時&#xff0c;永磁體也隨之轉動&#xff0c;產生周期性變化的磁場。霍爾傳感器靠近永磁體安裝&#xff0c;能夠檢測到磁…

(轉)正則化等最優化方法介紹

參考&#xff1a; http://blog.csdn.net/pipisorry/article/details/52108040 附帶 損失函數&#xff1b;經驗風險&#xff1b;正則化&#xff1b;結構風險 損失函數&#xff08;loss function&#xff09;是用來估量你模型的預測值f(x)與真實值Y的不一致程度&#xff0c;它是…

多維時序 | LightGBM多變量時序預測(Matlab完整源碼和數據,適合基礎小白研究)

多維時序 | LightGBM多變量時序預測&#xff08;Matlab完整源碼和數據&#xff0c;適合基礎小白研究&#xff09; 目錄 多維時序 | LightGBM多變量時序預測&#xff08;Matlab完整源碼和數據&#xff0c;適合基礎小白研究&#xff09;效果一覽基本介紹程序設計參考資料 效果一覽…

【解決】Android Gradle Sync 報錯 Could not read workspace metadata

異常信息 Caused by: java.io.UncheckedIOException:Could not read workspace metadata from C:\Users\xxx\.gradle\caches\transforms-4\69955912123c68eecd096b71c66ee211\metadata.bin 異常原因 看字面意思是不能讀取metadata文件&#xff0c;原因可能是因為緩存目錄異常…

Java面試實戰:電商場景下的Spring Cloud微服務架構與緩存技術剖析

第一輪提問 面試官: 謝飛機&#xff0c;我們先從基礎問題開始。請問你知道Spring Boot和Spring Cloud的區別嗎&#xff1f; 謝飛機: 當然知道&#xff01;Spring Boot主要用于快速構建獨立運行的Spring應用&#xff0c;而Spring Cloud則是在Spring Boot的基礎上實現分布式系統…

Express 路由使用、請求報文參數獲取、路由參數提取

Express 路由使用、請求報文參數獲取、路由參數提取 &#x1f6e3;? 一、Express 路由基本用法 const express require(express); const app express();// 基本 GET 路由 app.get(/, (req, res) > {res.send(Hello GET!); });// POST 路由 app.post(/submit, (req, res)…

【前端】手寫代碼輸出題易錯點匯總

兩天更新完。 const promise new Promise((resolve, reject) > {console.log(1);console.log(2); }); promise.then(() > {console.log(3); }); console.log(4); //1 //2 //4promise.then 是微任務&#xff0c;它會在所有的宏任務執行完之后才會執行&#xff0c;同時需…

基于深度學習和單目測距的前車防撞及車道偏離預警系統

隨著人工智能與計算機視覺技術的飛速發展,高級駕駛輔助系統(ADAS)已成為現代汽車智能化的關鍵標志。它不僅能有效提升行車安全,還能為自動駕駛時代的全面到來奠定堅實基礎。本文深入剖析一套功能完備、基于深度學習模型的 ADAS 系統的架構與核心實現,帶您領略智能駕駛背后…

JWT(JSON Web Token)用戶認證

1、頒發token <!--JWT依賴--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>0.9.1</version></dependency><dependency><groupId>javax.xml.bind</groupId>…

【質量管理】現代TRIZ(萃智)理論概述

一、什么是TRIZ理論 TRIZ理論,即發明問題解決理論(Teoriya Resheniya Izobreatatelskikh Zadatch),是由前蘇聯發明家根里奇阿奇舒勒(Genrich S. Altshuller)于1946年創立的。它是一門基于知識的、面向人的發明問題解決系統化方法學。TRIZ理論通過研究大量的專利,總結出技…

大模型學習筆記 day01 提示工程入門1.One-shot Few-shot提示學習法

如何應?和激發?語?模型的各??能? 提示?程 Prompt engineering 通過輸?更加合理的提示&#xff0c;引導模型進?更有效的結果輸出&#xff0c;本質上是?種引導和激發模型能?的?法更加輕量級的引導?法&#xff0c;嘗試和實施的?檻更低&#xff1b;問題是受限于模型…

FPGA初級項目10——基于SPI的DAC芯片進行數模轉換

FPGA初級項目10——基于SPI的DAC芯片進行數模轉換 DAC芯片介紹 DAC 芯片&#xff08;數字模擬轉換器&#xff09;是一種將數字信號轉換為連續模擬信號&#xff08;如電壓或電流&#xff09;的集成電路&#xff0c;廣泛應用于電子系統中&#xff0c;連接數字世界與模擬世界。 …

如何在 Windows上安裝 Python 3.6.5?

Windows 系統安裝步驟 下載安裝包 安裝包下載鏈接&#xff1a;https://pan.quark.cn/s/9294ca0fd46a 運行安裝程序 雙擊下載的 .exe 文件&#xff08;如 python-3.6.5.exe&#xff09;。 勾選 Add Python 3.6 to PATH&#xff08;重要&#xff01;這將自動配置環境變量&…

Cephalon端腦云:神經形態計算+邊緣AI·重定義云端算力

前引&#xff1a;當算力不再是“奢侈品” &#xff0c;在人工智能、3D渲染、科學計算等領域&#xff0c;算力一直是橫亙在個人與企業面前的“高墻”。高性能服務器價格動輒數十萬元&#xff0c;專業設備維護成本高&#xff0c;普通人大多是望而卻步。然而&#xff0c;Cephalon算…

【信息系統項目管理師】高分論文:論進度管理和成本管理(智慧城管平臺項目)

更多內容請見: 備考信息系統項目管理師-專欄介紹和目錄 文章目錄 論文1、規劃進度管理2、定義活動3、排列活動順序4、估算活動資源5、估算活動持續時間6、制定進度計劃7、控制進度論文 2018年8月,我作為項目經理參與了 XX市智慧城管平臺項目的建設,該項目投資500萬元人民幣…

WebAssembly:開啟高性能Web應用新時代

一、引言 隨著互聯網技術的飛速發展&#xff0c;Web應用的復雜度和性能要求越來越高。傳統的Web開發技術&#xff0c;如JavaScript&#xff0c;雖然功能強大&#xff0c;但在處理復雜計算和高性能需求時仍存在一些局限性。WebAssembly&#xff08;簡稱Wasm&#xff09;作為一種…

操作系統進程管理筆記

1. 進程的基本概念 1.1 進程的定義 進程就是運行中的程序。程序本身是沒有生命周期的&#xff0c;它只是存在磁盤上面的一些指令&#xff08;也可能是一些靜態數據&#xff09;。是操作系統讓這些字節運行起來&#xff0c;讓程序發揮作用。 1.2 CPU的時分共享 操作系統通過…

Python中random庫的應用

文章目錄 一、random 庫常用函數二、條件語句 隨機數示例1&#xff1a;隨機決定程序分支示例2&#xff1a;模擬概率事件 三、循環語句 隨機數示例1&#xff1a;循環直到滿足隨機條件示例2&#xff1a;隨機次數循環 四、隨機操作數據結構示例1&#xff1a;隨機打亂列表順序示例…

密碼學貨幣混幣器詳解及python實現

目錄 一、前言二、混幣器概述2.1 混幣器的工作原理2.2 關鍵特性三、數據生成與預處理四、系統架構與流程五、核心數學公式六、異步任務調度與 GPU 加速七、PyQt6 GUI 設計八、完整代碼實現九、自查測試與總結十、展望摘要 本博客聚焦 “密碼學貨幣混幣器實現”,以 Python + P…

各種各樣的bug合集

一、連不上數據庫db 1.可能是密碼一大包東西不對&#xff1b; 2.可能是里面某個port和數據庫不一樣&#xff08;針對于修改了數據庫但是連不上的情況&#xff09;&#xff1b; 3.可能是git代碼沒拉對&#xff0c;再拉一下代碼。? 二、沒有這個包 可能是可以#注釋掉。? …