[轉]Java8-本地緩存

這里我將會給大家演示用ConcurrentHashMap類和lambda表達式實現一個本地緩存。因為Map有一個新的方法可以在key為Null的時候自動計算一個新的value值。非常完美的實現cache。來看下代碼:

public static void main(String[] args) {for (int i = 0; i < 10; i++)System.out.println("f(" + i + ") = " + fibonacci(i));
}static int fibonacci(int i) {if (i == 0)return i;if (i == 1)return 1;System.out.println("Calculating f(" + i + ")");return fibonacci(i - 2) + fibonacci(i - 1);
}

當然,這種方式很傻瓜了。即使對于一個非常小的數,例如fibonacci(5),上面的代碼打印出很多行,而且都是在進行重復計算,輸出如下(只截取一部分):

Calculating f(6)
Calculating f(4)
Calculating f(2)
Calculating f(3)
Calculating f(2)
Calculating f(5)
Calculating f(3)
Calculating f(2)
Calculating f(4)
Calculating f(2)
Calculating f(3)
Calculating f(2)
f(6) = 8

我們想要做的就是創建一個緩存,用來計算斐波那契數列。最直接的方法就是在緩存中存放所有的value值。cache的創建如下:

static Map<Integer, Integer> cache = new ConcurrentHashMap<>();

(譯者注:這種寫法在Java8中是允許的)

聲明cache之后,通過Map.computeIfAbsent() 方法,可以在key所對應的value值不存在的情況下,計算一個新的value值。超高速緩存(Caching)!由于這個方法是自動執行的,而且我們使用了 ConcurrentHashMap對象,這個緩存是線程安全的,不需要手動的去寫同步方法。另外,它不僅僅可以處理斐波那契額數列,在其他地方也可以被重復使用。

不過現在,我們看看如何在fibonacci()方法中使用緩存。

static int fibonacci(int i) {if (i == 0)return i;if (i == 1)return 1;return cache.computeIfAbsent(i, (key) ->fibonacci(i - 2)+ fibonacci(i - 1));
}

瞧瞧。不能比這個再簡單了吧。想要證明嗎?好吧,每當我們計算一個新值的時候,都在控制臺輸出信息:

static int fibonacci(int i) {if (i == 0)return i;if (i == 1)return 1;return cache.computeIfAbsent(i, (key) -> {System.out.println("Slow calculation of " + key);return fibonacci(i - 2) + fibonacci(i - 1);});
}

程序輸出如下:

f(0) = 0
f(1) = 1
Slow calculation of 2
f(2) = 1
Slow calculation of 3
f(3) = 2
Slow calculation of 4
f(4) = 3
Slow calculation of 5
f(5) = 5
Slow calculation of 6
f(6) = 8
Slow calculation of 7
f(7) = 13
Slow calculation of 8
f(8) = 21
Slow calculation of 9
f(9) = 34

在Java7下又如何實現呢?

這樣代碼就會多一些,我們可以使用double-checked locking來實現:

static int fibonacciJava7(int i) {if (i == 0)return i;if (i == 1)return 1;Integer result = cache.get(i);if (result == null) {synchronized (cache) {result = cache.get(i);if (result == null) {System.out.println("Slow calculation of " + i);result = fibonacci(i - 2)+ fibonacci(i - 1);cache.put(i, result);}}}return result;
}

注:你實際的解決方案很可能會用到Guava Caches。

總結:Lambdas 表達式是Java8中非常重要的一部分。我們不要忘記添加到庫中的所有的新特性。

原文鏈接: Jooq 翻譯: ImportNew.com - 宋 濤
譯文鏈接: http://www.importnew.com/10227.html

-----------------------分割線--------------------------------------------------

目前Oracle官方還未放出JDK1.8 的?Documentation ,查看API可以訪問URL:http://download.java.net/jdk8/docs/api/

轉載于:https://www.cnblogs.com/GYoungBean/p/3604412.html

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

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

相關文章

python opencv圖像處理程序_Python-OpenCV學習(四):基本圖像處理

轉載請注明出處&#xff1a;danscarlett的博客園 參考資料&#xff1a; 目錄&#xff1a; 讀取 imread 顯示 imshow 存儲 imwrite 縮放 resize 加邊框 copyMakeBorder 裁剪 img[x_start:x_end,y_start:y_end] 1.圖像讀取&#xff1a; cv2.imread(fileName,flagsNone) 函數功能&…

Java進程占用CPU資源過多分析

問題描述&#xff1a; 生產環境下的某臺tomcat7服務器&#xff0c;在剛發布時的時候一切都很正常&#xff0c;在運行一段時間后就出現CPU占用很高的問題&#xff0c;基本上是負載一天比一天高。 問題分析&#xff1a; 1&#xff0c;程序屬于CPU密集型&#xff0c;和開發溝通過&…

分針網——怎么輕松學習JavaScript

js給初學者的印象總是那么的“雜而亂”&#xff0c;相信很多初學者都在找輕松學習js的途徑。我試著總結自己學習多年js的經驗&#xff0c;希望能給后來的學習者探索出一條“輕松學習js之路”。js給人那種感覺的原因多半是因為它如下的特點&#xff1a;A&#xff1a;本身知識很抽…

MATLAB中floor、round、ceil、fix區別

Matlab取整函數有: fix, floor, ceil, round.具體應用方法如下&#xff1a;fix朝零方向取整&#xff0c;如fix(-1.3)-1; fix(1.3)1;floor&#xff0c;顧名思義&#xff0c;就是地板&#xff0c;所以是取比它小的整數&#xff0c;即朝負無窮方向取整&#xff0c;如floor(-1.3)-2…

python時間序列分析航空旅人_用python做時間序列預測一:初識概念

利用時間序列預測方法&#xff0c;我們可以基于歷史的情況來預測未來的情況。比如共享單車每日租車數&#xff0c;食堂每日就餐人數等等&#xff0c;都是基于各自歷史的情況來預測的。 什么是時間序列&#xff1f; 時間序列&#xff0c;是指同一個變量在連續且固定的時間間隔上…

解決mysql不能遠程登入的問題

mysql遠程不能登入&#xff0c;問題就在于當時設置的賬號只限制本地訪問&#xff0c;mysql默認也只是本地訪問。之前的設置&#xff1a; 通過命令行登錄管理MySQL服務器&#xff08;提示輸入密碼時直接回車&#xff09;&#xff1a; mysql> /usr/local/webserver/mysql/bin/…

ASCII碼、HEX、字符、BCD 等等 基礎知識思考

每每遇到這些問題就要想個半天&#xff0c;想不明白還不舒服&#xff0c;今天特別把所想整理下避免以后再次進入思想漩渦&#xff01;&#xff01;&#xff01;計算機存儲和傳輸都是以字節為單位 1 bit 1 二進制數據 1 byte 8 bit 1 字母 1 by…

[Logstash-input-redis] 使用詳解

2019獨角獸企業重金招聘Python工程師標準>>> Redis插件參數配置詳解 工作流程 logstash啟動redis插件redis插件獲取參數&#xff0c;進行校驗工作判斷監聽模式(list,channel,pattern_channel等)&#xff0c;根據不同的監聽模式創建監聽任務創建redis實例&#xff0c…

雅可比旋轉求解對稱二維矩陣的特征值和特征向量

問題描述&#xff1a; 給定一個矩陣&#xff0c;如下&#xff1a; A[a11a21a12a22]A=\begin{bmatrix} a_{11}&a_{12}\\ a_{21}& a_{22} \end{bmatrix} 其中滿足a12a21.也就是所謂的 對稱矩陣。那么如何求解此矩陣的特征值以及特征向量呢&#xff1f;這里我們要用到 …

游戲場景燈光烘焙

【LV4】北京 天殺神(153478394) 10:21:15可能是我找的截圖不好 我就是想問下 一般要烘焙這樣的一個場景的步驟是什么 【LV5】北京地編&#xff5e;mr(274380109) 10:21:44首先就看原畫的色調 確定一個環境光如果是晴天 就打一個直光 給陰影 直光不要太亮 【LV5】北京地編&a…

python畫圖數據的平均值怎么算的_Python氣象數據處理與繪圖(2):常用數據計算方法...

對于氣象繪圖來講&#xff0c;第一步是對數據的處理&#xff0c;通過各類公式&#xff0c;或者統計方法將原始數據處理為目標數據。 按照氣象統計課程的內容&#xff0c;我給出了一些常用到的統計方法的對應函數&#xff1a; import numpy as np 平均值 在計算氣候態&#xff0…

Linux下nginx安裝與配置

部分Linux發布版的默認安裝已經集成了nginx&#xff0c;查看方法ls /usr/local&#xff0c;若已有nginx文件夾說明已集成。nginx依賴庫pcre與zlib&#xff0c;且pcre依賴于gcc與gcc-c&#xff0c;因此安裝步驟為&#xff1a;安裝gcc與gcc-c庫安裝pcre庫安裝zlib庫安裝nginx詳細…

java 讀取properties文件

1.不在項目中讀取 Properties properties new Properties();BufferedReader read new BufferedReader(new InputStreamReader(new FileInputStream("文件的路徑"),"utf-8"));properties.load(read);properties .getProperty("那個文件的key") …

幾種字符串加密解密的方法

為什么80%的碼農都做不了架構師&#xff1f;>>> 第一種&#xff1a;〔 Python 與 Bash Shell 的結合 〕 這個命令會讓你輸入一個字符串&#xff0c;然后會再輸出一串加密了的數字。 加密代碼[照直輸入]: python -c print reduce(lambda a,b: a*256ord(b), raw_inpu…

java delegate怎么寫_美團面試官:你說你們公司的Mybatis分頁插件是你寫的,給我說說它的設計原理?...

來源&#xff1a;http://my.oschina.net/zudajun大多數框架&#xff0c;都支持插件&#xff0c;用戶可通過編寫插件來自行擴展功能&#xff0c;Mybatis也不例外。我們從插件配置、插件編寫、插件運行原理、插件注冊與執行攔截的時機、初始化插件、分頁插件的原理等六個方面展開…

C++標準庫與Java基礎類對照表

一、集合類對象的集合&#xff0c;指如鏈表&#xff0c;數組&#xff0c;隊列這一類的數據結構。在C標準庫中把這些成為Container, 在Java中稱為Collection。CSTL常用Container&#xff1a; vector, list, map, set, queue, stack, priority_queueJava基礎類&#xff1a;ArrayL…

ASP.NET MVC 在控制器中獲取某個視圖動態的HTML代碼

如果我們需要動態的用AJAX從服務器端獲取HTML代碼&#xff0c;拼接字符串是一種不好的方式&#xff0c;所以我們將HTML代碼寫在cshtml文件中&#xff0c;然后通過代碼傳入model&#xff0c;動態獲取cshtml中的HTML代碼 當然&#xff0c;我們想要使用通用的方法去獲取cshtml&…

SharePoint 2013 處理videoplayerpage.aspx下的個人圖片顯示有誤問題

問題&#xff1a;Personal sites photo cant correct display in the videos pageThe url address of personal sites photo is exist surplus characters. The correct situation is just the characters of "%20", not the characters of "%2520".解決方…

Python學習筆記(一)

1.python語言的優點&#xff1a;(1)是一種高級語言&#xff0c;提供大量的庫和內置數據結構(2)書寫簡潔優美 缺點:是解釋性語言&#xff0c;執行速度較慢 2.從官方網站下載的python解釋器為CPython,是一種用C語言編寫的python解釋器。在命令行如果啟動python3&#xff0c;輸入p…

匯編語言基本概念匯總

匯編語言應該是我們如今學的最“低級”的語言了&#xff0c;由于如今不會再有人去學機器語言了。而匯編語言還在一些硬件或者嵌入式設備上使用并開發著。下面資料是為了大學的匯編考試整理的資料&#xff0c;如今與大家分享&#xff0c;希望能給大家提供幫助。 匯編語言程序設計…