java cache详解,Java内存缓存详解
1.緩存為什么要存在
應用服務器資源是有限的,數據庫每秒中接受請求的次數也是有限的。如果利用有限的資源來提供盡可能大的吞吐量呢,一個辦法:減少計 算量,縮短請求流程(減少網絡io或者硬盤io),這時候緩存就可以大展手腳了
2.什么樣的數據可以存到緩存中
一段時間內不變的數據
3.為什么要有本地緩存
在系統中,有些數據,數據量小,但是訪問十分頻繁(例如國家標準行政區域數據),針對這種場景,需要將數據搞到應用的本地緩存中,以提升系統的訪問效率,減 少無謂的數據庫訪問(數據庫訪問占用數據庫連接,同時網絡消耗比較大),但是有一點需要注意,就是緩存的占用空間以及緩存的失效策略。
4.內存緩存或本地緩存的原理
實現緩存的方式就是使用Map,而緩存的實現則主要分為三大步驟:第一:先到緩存里面查找是否有我們需要的對象,若是存在,則直接返回。第二:若是緩存里面沒有該對象,則將其數據添加到緩存中去。以備下次使用。第三:如果找到了相應的數據,或者是創建了相應的數據,那就直接使用這個數據。然而,java中Map對象的key設置為String類型,也是為了查找的方便。
實際上是建立一個Map集合類實現把緩存的內容保存到內存里面,只要服務器沒有關閉緩存就不會被清除,除非人為清除
importjava.util.Map;importjava.util.concurrent.ConcurrentHashMap;public classCacheClass {private static Map cache = new ConcurrentHashMap();public static void setCache(String key, String obj, longseconds){
cache.put(key,obj);
}public staticString getCache(String key){returncache.get(key);
}public static voidremoveCache(String key){
cache.remove(key);
}public static voidmain(String args[]){
removeCache("China");
String name= getCache("China");
System.out.println("name="+name);
setCache("China","中國",60*60*24*30);
name= getCache("China");
System.out.println("第二次取值name="+name);
removeCache("China");
name= getCache("China");
System.out.println("第三次取值name="+name);
}
}
總結
以上是生活随笔為你收集整理的java cache详解,Java内存缓存详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: asp.net接受表单验证格式后再提交数
- 下一篇: Java Web访问.action_ja