读写锁是线程读写同一文件所需要用到的,读写锁是什么东西在这里不做过多的解释,可以自己去百度或谷歌去搜一下。
谨在此附上我自己写的缓存系统的简单实现,你从中也能悟出缓存实现的基本思想
缓存里面有数据就从缓存中取,没有就给你从其他地方得到。
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 cache = new HashMap();
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;
}
}
分享到:
2011-09-21 16:01
浏览 1784
评论
1 楼
zhenglutan
2012-05-06
if(obj == null)
{
obj = new String("obj is get from db");
}
第二次做这种判断有点问题,多线程环境下仍有可能会执行多遍,这里的obj为局部变量,并不能同步更新引用,与API的实现还是有区别的。