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 缓存机制

  • 2015年06月23日 10:30
  • 151KB
  • 下载

java 自动装箱拆箱及 数据对象的缓存机制详解

近段时间由于准备要找工作,就看起了源码,以前只知道,java 中的 Integer String 等类为了优化系统,采用了一系列的高速缓存机制,来提升系统的性能,但由于是在是太忙(太懒)故没有好好的研...

Java 学习笔记03:Spring 3.0 核心机制 IoC

什么是Spring的IOC Spring的核心机制是IOC。通常被称为“控制反转”,也被叫做“依赖注入”。它是一种设计模式,由框架或者容器将被调用的类注入给调用对象,以此来解除调用对象和被调用类...
  • initphp
  • initphp
  • 2012年11月15日 13:56
  • 1840

Java学习之类加载全过程_JVM内存分析_反射机制核心原理_常量池理解

一、类加载机制 JVM把class文件加载到内存,并对数据进行校验,解析和初始化,最形成JVM可以直接使用的JAVA类型的过程。加载-->链接(-->验证-->准备-->解析)-->初始化-->使用...

Java学习篇之---小整数缓存机制

Java学习篇之---为什么100==100返回true,1000==1000返回false 这是一个有意思的话题。如果你运行如下代码: Integer a = 1000, b = 1000; S...

Java缓存机制之Map实现

最近遇到一些问题,就是系统会需要频繁的使用一些数据,这些数据的更改较少,如果每次使用都从数据库查找,这无疑影响系统的性能。 经过网上的资料查找以及自己的实验,找到了一种方法解决该问题的方法,即缓存。...

java对象本地缓存机制的实现

本地缓存机制,利用java.util.concurrent,很好的管理本地内存存储的对象内容。 创建属性:  /**      * 具体内容存放的地方      */    ...

Java缓存Ehcache-Ehcache的Cache预热机制及代码实现(Cache Warming for multi-tier Caches)

Ehcache中Cache预热机制 Cache预热机制简介 Ehcache在程序启动的时候并不会立即去加载位于磁盘上的数据到内存,而是在数据被用到的时候去加载(lazy load)。因此在cach...

Java中常用缓存Cache机制的实现

缓存主要可分为二大类:   一、通过文件缓存,顾名思义文件缓存是指把数据存储在磁盘上,不管你是以XML格式,序列化文件DAT格式还是其它文件格式;   二、内存缓存,也就是实现一个类中静态...

Java 中常用缓存Cache机制的实现

所谓缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例。这样做可以减少系统开销,提高系统效率。 缓存主要可分为二大类: 一、通过文件缓存...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java教程、java学习:Java数据缓存实现的核心机制
举报原因:
原因补充:

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