Java数据缓存实现的核心机制

开发 后端
在大数据量访问读取中,数据缓存是最普遍采用的解决方案之一,但在读过很多代码的缓存实现,代码可圈可点的弹性都很大,在一并发数不多时,功能是完全没有问题的,但是对大数量的多并发操作上就有些差强人意了。以下为集数家之长实现的数据缓存核心机制代码片段,以抛砖引玉,供大家学习,此片段的核心代码参考sun的源码实现。

在大数据量访问读取中,数据缓存是最普遍采用的解决方案之一,但在读过很多代码的缓存实现,代码可圈可点的弹性都很大,在一并发数不多时,功能是完全没有问题的,但是对大数量的多并发操作上就有些差强人意了。以下为集数家之长实现的数据缓存核心机制代码片段,以抛砖引玉,供大家学习,此片段的核心代码参考sun的源码实现。

sun没有对此段代码开放,它的功能在ArrayBlockingQueue(jdk1.5)中已经实现并提供开放接口。没有时间看下面的代码的可直接查看ArrayBlockingQueue的api,如果对象ArrayBlockingQueue也没有兴趣的同学,可以直接调用ConcurrentHashMap(jdk1.5), ConcurrentSkipListMap(jdk1.6),这些类,api中有更加祥细的说明,这里不多说,需要注意的是因为此功能解决多线程并发问题,故null不能做为key和value的键值,可以理解为HashTable的提升。

  1. package com.henry;  
  2.  
  3. import java.util.HashMap;  
  4. import java.util.Map;  
  5. import java.util.Random;  
  6. import java.util.concurrent.locks.ReadWriteLock;  
  7. import java.util.concurrent.locks.ReentrantReadWriteLock;  
  8.  
  9. public class CacheDataTest {  
  10. static Map<Integer,Object> dataMap=new HashMap<Integer,Object>();  
  11. static ReadWriteLock lock=new ReentrantReadWriteLock();//创建读写锁的实例  
  12. static Object getData(Integer key){  
  13. lock.readLock().lock();//读取前先上锁  
  14. Object val=null;  
  15. try{  
  16. val=dataMap.get(key);  
  17. if(val == null){  
  18. // Must release read lock before acquiring write lock  
  19. lock.readLock().unlock();  
  20. lock.writeLock().lock();  
  21. tryif(val==null){  
  22. //dataMap.put(key, "");//query from db  
  23. val=queryDataFromDB(key); }finally{  
  24. //Downgrade by acquiring read lock before releasing write lock  
  25. lock.readLock().lock();  
  26. // Unlock write, still hold read  
  27. lock.writeLock().unlock(); }  
  28. }finally{  
  29. lock.readLock().unlock();//最后一定不要忘记释放锁 System.out.println("get data key="+key+">val="+val);  
  30. return val;   
  31. static Object queryDataFromDB(Integer key){  
  32. Object val=new Random().nextInt(1000);  
  33. dataMap.put(key, val);  
  34. System.out.println("write into data key="+key+">val="+val);  
  35. return val;  
  36. }  
  37.  
  38.  
  39. public static void main(String[] args) {  
  40. for(int i=0;i<10;i++){  
  41. new Thread(new Runnable(){public void run() {  
  42. getData(new Random().nextInt(5));  
  43. }}).start(); }  

原文链接:http://www.cnblogs.com/cx361/archive/2011/12/14/2287025.html

【编辑推荐】

  1. Java的标准数据流
  2. 影响Java NIO框架性能的因数
  3. Java的NIO以及线程并发
  4. 微软警告称Java乃入侵目标之首
  5. JavaScript 6看上去很美
责任编辑:林师授 来源: 十分爱的博客
相关推荐

2012-07-03 10:57:54

Hadoop核心机制

2013-08-02 14:19:50

Java日志缓存

2024-07-30 12:24:23

2010-09-14 09:30:04

Java多态

2014-11-04 10:34:27

JavaCache

2024-02-21 12:14:00

Gochannel​panic​

2011-07-13 09:12:36

2013-07-08 09:59:47

思科核心机箱思科交换机思科

2024-09-02 09:00:59

2011-07-15 09:57:03

MongoDB缓存刷新

2009-08-03 18:35:51

ASP.NET数据缓存

2019-11-14 14:30:10

Java类反射代码

2021-05-14 11:26:47

大数据

2015-09-28 15:59:00

Java动态代理机制

2011-03-16 09:26:41

ReadWriteLoJava

2009-11-23 17:56:44

PHP缓存机制

2009-06-18 14:51:12

Hibernate缓存Hibernate

2024-04-01 08:29:09

Git核心实例

2017-07-04 09:53:49

机房运维机房电源

2010-09-26 14:08:41

Java垃圾回收
点赞
收藏

51CTO技术栈公众号