緩存代理

User$Proxy extends User{

       private Integer id;

       User realUser=null;

      getName(){

            if(realUser==null){

                  realUser.session.get(i)

                  if(realUser==null) throw Exception

            }

            return realUser.getName();

      }

}

-------

//j2se api中ReentrantReadWriteLock類的示例,下面的代碼展示瞭如何利用重入來執行升級緩存後的鎖降級

 class CachedData {

   Object data;
   volatile boolean cacheValid;
   ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();

   void processCachedData() {
     rwl.readLock().lock();
     if (!cacheValid) {
        // Must release read lock before acquiring write lock
        rwl.readLock().unlock();
        rwl.writeLock().lock();
        // Recheck state because another thread might have acquired
        //   write lock and changed state before we did.
        if (!cacheValid) {
          data = ...
          cacheValid = true;
        }
        // Downgrade by acquiring read lock before releasing write lock
        rwl.readLock().lock();
        rwl.writeLock().unlock(); // Unlock write, still hold read
     }

     use(data);
     rwl.readLock().unlock();
   }
 }

-----------------------------------------------

public class CacheDemo//緩存
{
    private Map<String,Object> cache=new HashMap<String,Object>();
    ReadWriteLock rwl=new ReentrantReadWriteLock();
    public void process(String key){
        rwl.readLock().lock();
        Object value=null;
        try
        {
            value=cache.get(key);
            if(value==null){
                rwl.readLock().unlock();
                rwl.writeLock().lock();
                if(value==null){
                    value="aaa";//queryDB 去數據庫中查詢
                    if(value!=null){
                        cache.put(key,value);
                    }
                }
                try
                {
                    rwl.writeLock().unlock();
                }
                catch (Exception e)
                {
                    e.printStackTrace();
                }finally{
                    rwl.writeLock().unlock();
                }
                rwl.readLock().lock();
            }
        }
        catch (Exception e)
        {
            e.printStackTrace();
        }finally{
            rwl.readLock().unlock();
        }
        
    }
}


發佈了38 篇原創文章 · 獲贊 6 · 訪問量 11萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章