您的位置:首页 > 编程语言 > Java开发

java中读写锁的实现及使用读写锁简单实现缓存系统的实例

2011-09-21 16:01 721 查看

读写锁是线程读写同一文件所需要用到的,读写锁是什么东西在这里不做过多的解释,可以自己去百度或谷歌去搜一下。

谨在此附上我自己写的缓存系统的简单实现,你从中也能悟出缓存实现的基本思想

缓存里面有数据就从缓存中取,没有就给你从其他地方得到。

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; } }


阅读更多
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: