本文介紹了EHCache3.5獲取所有緩存鍵/條目的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我使用的是EHCache 3.5.2,獲取所有緩存鍵和緩存項時遇到問題。
我正在使用CacheManager創建緩存。然后我用一些數據填充它。然后,我希望檢索緩存中的所有條目。
一些示例代碼:
Cache<String, Foo> cache = cacheManager.createCache("fooCache",
CacheConfigurationBuilder.newCacheConfigurationBuilder(String.class, Foo.class,
ResourcePoolsBuilder.heap(20)).build());
cache.putAll(repository.findAll().stream().collect(toMap(Foo::getId, foo -> foo)));
List<Foo> foos = cache.???
List<String> keys = cache.???
v3.5可以做到這一點嗎?這似乎在舊版本的EHCache中是可能的。
謝謝
api
按照設計,這不是一個簡單的推薦答案調用。由于JVM支持的分層模型,實現堆上的所有鍵或值可能會導致JVM內存不足。
如其他答案所示,有實現此目的的方法。
但必須一次獲取緩存的全部內容被視為緩存反模式。
這篇關于EHCache3.5獲取所有緩存鍵/條目的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,