Guava在實際的Java后端項目中應用的場景還是比較多的,比如限流,緩存,容器操作之類的,有挺多實用的工具類,這里記錄一下,在使用GuavaCache,返回null的一個問題
I. 常見使用姿勢
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
@Test public void testGuava() { LoadingCache<String, String> cache = CacheBuilder.newBuilder().build( new CacheLoader<String, String>() { @Override public String load(String key) throws Exception { if ( "hello" .equals(key)) { return "word" ; } return null ; } }); String word = cache.getUnchecked( "hello" ); System.out.println(word); System.out.println(cache.getUnchecked( "word" )); } |
上面是一個非常簡單的測試case,需要注意的是,cache.get("word") 的執行,并不如逾期的返回的是null,而是會拋一個異常出來
word
com.google.common.cache.CacheLoader$InvalidCacheLoadException: CacheLoader returned null for key word.
at com.google.common.cache.LocalCache$Segment.getAndRecordStats(LocalCache.java:2287)
...
從異常描述能看出,不允許返回null,這一塊之前倒是沒怎么注意,因此對于null的情況,要么定義一個標記表示不存在,要么在load()方法中主動拋一個異常出來,在使用的時候注意下,通過異常的使用方式,可以如下
1
2
3
4
5
6
7
8
9
10
|
public class NoVlaInGauvaException extends Exception { public NoVlaInGauvaException(String msg) { super (msg); } @Override public synchronized Throwable fillInStackTrace() { return this ; } } |
說明:為什么重寫fillInStackTrace方法
對于這種緩存未命中的情況下,一般而言是不需要關注完整的堆棧信息的,沒有數據而已,可以節省一點點性能(當然除非是在高頻率的拋出時,才會有表現癥狀)
其次就是get與getUnchecked的區別了
- get要求顯示處理exception狀況
- getUnchecked 一般是可確認不會有問題的場景,直接調用
改造之后,我們的cache如下
1
2
3
4
5
6
7
8
9
|
LoadingCache<String, String> cache = CacheBuilder.newBuilder().build( new CacheLoader<String, String>() { @Override public String load(String key) throws Exception { if ( "hello" .equals(key)) { return "word" ; } throw new NoVlaInGauvaException(); } }); |
到此這篇關于淺談Java中GuavaCache返回Null的注意事項的文章就介紹到這了,更多相關GuavaCache返回Null內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://juejin.cn/post/7024826582405480478