讀寫鎖是線程讀寫同一文件所需要用到的,讀寫鎖是什麼東西在這裡不做過多的解釋,可以自己去百度或谷歌去搜一下。
謹在此附上我自己寫的緩存系統的簡單實現,你從中也能悟出緩存實現的基本思想
緩存裡面有數據就從緩存中取,沒有就給你從其他地方得到。
[java]
- package cn.com.scl.cache
- import java.util.HashMap;
- import java.util.Map;
- import java.util.concurrent.locks.ReadWriteLock;
- import java.util.concurrent.locks.ReentrantReadWriteLock;
- /**
- * 緩存的實現,每個線程只能獲得他自己的緩存,也應該是單例的
- * 本類沒有去實現單例,如果需要的話可以自行去實現
- * @author scl
- *
- */
- public class CacheSystem {
- private Map<String, Object> cache = new HashMap<String,Object>();
- private ReadWriteLock rwl = new ReentrantReadWriteLock();
- public Object getData(String key){
- //先從緩存中去取數據,先加上讀鎖
- rwl.readLock().lock();
- Object obj = null;
- try{
- obj = cache.get(key);
- if(obj == null){
- //先解除讀鎖,在上寫鎖(必須先解除讀鎖才能成功上寫鎖)
- rwl.readLock().unlock();
- rwl.writeLock().lock();
- //去數據庫取數據,再判斷一次是否為null,因為有可能多個線程獲得寫鎖
- try{
- if(obj == null){
- obj = new String("obj is get from db");
- }
- }finally{
- //先上讀鎖,然後再解除寫鎖(這樣可以成功完成,在解除寫鎖前獲得讀鎖,寫鎖被降級--這翻譯的api上的)
- rwl.readLock().lock();
- rwl.writeLock().unlock();//解除寫鎖,讀鎖仍然持有
- }
- }
- }finally{
- rwl.readLock().unlock();
- }
- return obj;
- }
-
- }