java教程、java学习:Java数据缓存实现的核心机制

原创 2016年05月31日 09:19:54
      在大数据量访问读取中,数据缓存是最普遍采用的解决方案之一,但在读过很多代码的缓存实现,代码可圈可点的弹性都很大,在一并发数不多时,功能是完全没有问题的,但是对大数量的多并发操作上就有些差强人意了。
      以下为集数家之长实现的数据缓存核心机制代码片段,以抛砖引玉,供大家学习,此片段的核心代码参考sun的源码实现。
     sun没有对此段代码开放,它的功能在ArrayBlockingQueue(jdk1.5)中已经实现并提供开放接口。没有时间看下面的代码的可直接查看ArrayBlockingQueue的api,如果对象ArrayBlockingQueue也没有兴趣的同学,可以直接调用ConcurrentHashMap(jdk1.5), ConcurrentSkipListMap(jdk1.6),这些类,api中有更加祥细的说明,这里不多说,需要注意的是因为此功能解决多线程并发问题,故null不能做为key和value的键值,可以理解为HashTable的提升。
  1. package com.henry;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. import java.util.Random;
  5. import java.util.concurrent.locks.ReadWriteLock;
  6. import java.util.concurrent.locks.ReentrantReadWriteLock;
  7. public class CacheDataTest {
  8. static Map<Integer,Object> dataMap=new HashMap<Integer,Object>();
  9. static ReadWriteLock lock=new ReentrantReadWriteLock(); //创建读写锁的实例
  10. static Object getData(Integer key){
  11. lock.readLock().lock();//读取前先上锁
  12. Object val=null;
  13. try{
  14. val=dataMap.get(key);
  15. if(val == null){
  16. // Must release read lock before acquiring write lock
  17. lock.readLock().unlock();
  18. lock.writeLock().lock();
  19. try{ if(val==null){
  20. //dataMap.put(key, "");//query from db
  21. val=queryDataFromDB(key);
  22. }finally{
  23. //Downgrade by acquiring read lock before releasing write lock
  24. lock.readLock().lock();
  25. // Unlock write, still hold read
  26. lock.writeLock().unlock(); }
  27. }finally{
  28. lock.readLock().unlock();
  29. //最后一定不要忘记释放锁 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. public static void main(String[] args) {
  38. for(int i=0;i<10;i++){
  39. new Thread(new Runnable(){public void run() {
  40. getData(new Random().nextInt(5)); }
  41. }
  42. ).start(); }
  43. }

学习有困难可以加扣:578024144进行交流还可以关注微信公众号:javaniuniu获取免费得听课权限!

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

java学习、java入门:Java如何学?我的经验告诉你

以下三点是必须要做到的: 1:课前认真预习; 2:课上认真听讲; 3: 课后认真复习,勤练代码。

java学习、java入门我为什么要学习Java EE?

学习了Java SE,还只是完成“万里长征”的第一步。 选择学习Java EE或是Java ME(或者你还想不断深入学习Java SE,只要你喜欢,你可以一直深入下去);估计选择Java EE方面的...

java学习:java 基础语法你都了解清楚了吗?

很多同学都说Java难学,其实,如果你把Java的基础语法掌握好了,就很好学了!信狮的学子们,我们来看看要?

java入门、java学习:菜鸟入门Java程序学习的要点

菜鸟入门Java程序学习的要点

Java新手学习路线java教程(下)

第五经典阶段:web主流框架技术(项目实战) struts2.x; . struts2框架的工作原理和架构分析,struts-default.xml与default.properties文件的作用,...

java教程:开发┃java学习中的13个核心技术

开发┃java学习中的13个核心技术

java入门、java学习:如何理解Java面向对象

首先要说明一点,对象不是java的,事实上他只是一种概念,一种用于解决问题的程序设计的思想方法。要理解对象就必须得要和面向对象结合起来。在面向对象中把某一类事物所共有的属性和行为抽象出来之后就形成了一...

java学习、java教程:如何学java开发工程师

如何学java开发工程师,我们一起来探讨一下学习方法,希望对学习的朋友有所帮助。   如何学java开发工程师------学习Java之前,先看看自己是否适合、对学Java开发工程师是否有兴趣?是...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)