`

EHCache 缓存全接触

阅读更多

EHCache 是一个纯java的,在Hibernate2.1充当可插入的的在进程中的缓存,它具有以下缓存,最小的依赖性,全面的文特性:快速,简单,丰富的文档和测试用例。

     官方网站 http://ehcache.sourceforge.net/ 


     ehcache-1.2 cacheNames 列表的取得;

     方法一:

  1. CacheManager.create();   
  2. String[] cacheNames = CacheManager.getInstance().getCacheNames();  

     方法二:

  1. CacheManager manager = new CacheManager();   
  2. String[] cacheNames = manager.getCacheNames();  

     方法三:

  1. CacheManager manager1 = new CacheManager('src/config/ehcache1.');   
  2. CacheManager manager2 = new CacheManager('src/config/ehcache2.xml');   
  3. String[] cacheNamesForManager1 = manager1.getCacheNames();   
  4. String[] cacheNamesForManager2 = manager2.getCacheNames();  


     ehcache-1.2 管理器各种建立的方法:

     方法一:

  1. CacheManager manager = new CacheManager();  

     方法二:

  1. CacheManager manager = new CacheManager('src/config/ehcache.xml');  

     方法三:

  1. URL url = getClass().getResource('/anotherconfigurationname.xml');   
  2. CacheManager manager = new CacheManager(url);  

     方法四:

  1. InputStream fis = new FileInputStream(new File('src/config/ehcache.xml').getAbsolutePath());   
  2. try {   
  3.     CacheManager manager = new CacheManager(fis);   
  4. finally {   
  5.     fis.close();   
  6. }  


     添加和删除缓存元素

         设置一个名为test 的新cache,test属性为默认

  1. CacheManager singletonManager = CacheManager.create();   
  2. singletonManager.addCache('testCache');   
  3. Cache test = singletonManager.getCache('testCache');  

         设置一个名为test 的新cache,并定义其属性 

  1. CacheManager singletonManager = CacheManager.create();   
  2. Cache memoryOnlyCache = new Cache('testCache'5000falsefalse52);   
  3. manager.addCache(memoryOnlyCache);   
  4. Cache test = singletonManager.getCache('testCache');  


        
         Cache 属性说明:

             构造函数:
             public Cache(java.lang.String name,
                          int maxElementsInMemory,
                          boolean overflowToDisk,
                          boolean eternal,
                          long timeToLiveSeconds,
                          long timeToIdleSeconds)

             参数说明:
             name                           - 元素名字。
                 maxElementsInMemory            - 设定内存中创建对象的最大值。
                 overflowToDisk                 - 设置当内存中缓存达到 maxInMemory 限制时元素是否可写到磁盘
                                                        上。
                 eternal                        - 设置元素(译注:内存中对象)是否永久驻留。如果是,将忽略超
                                                       时限制且元素永不消亡。
                 timeToIdleSeconds              - 设置某个元素消亡前的停顿时间。
                                                       也就是在一个元素消亡之前,两次访问时间的最大时间间隔值。
                                                       这只能在元素不是永久驻留时有效(译注:如果对象永恒不灭,则
                                                       设置该属性也无用)。
                                                       如果该值是 0 就意味着元素可以停顿无穷长的时间。
                 timeToLiveSeconds              - 为元素设置消亡前的生存时间。
                                                        也就是一个元素从构建到消亡的最大时间间隔值。
                                                        这只能在元素不是永久驻留时有效。

         删除缓存元素:

  1. CacheManager singletonManager = CacheManager.create();   
  2. singletonManager.removeCache('test');  


     关闭缓存管理器 CacheManager

  1. CacheManager.getInstance().shutdown();  


     对于缓存对象的操作:
         放入一个简单的对象到缓存元素;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. Element element = new Element('key1''value1');   
  3. cache.put(element);  

         得到一个序列化后的对象属性值;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. Element element = cache.get('key1');   
  3. Serializable value = element.getValue();  

         得到一个没有序列化后的对象属性值;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. Element element = cache.get('key1');   
  3. Object value = element.getObjectValue();  

         删除一个对象从元素;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. Element element = new Element('key1''value1'  
  3. cache.remove('key1');  

     对于永固性磁盘存储,立即存储到磁盘:

  1. Cache cache = manager.getCache('sampleCache1');   
  2. cache.flush();  


     获得缓存大小:
         得到缓存的对象数量;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int elementsInMemory = cache.getSize();  

         得到缓存对象占用内存的数量

  1. Cache cache = manager.getCache('sampleCache1');   
  2. long elementsInMemory = cache.getMemoryStoreSize();  

         得到缓存对对象占用磁盘的数量

  1. Cache cache = manager.getCache('sampleCache1');   
  2. long elementsInMemory = cache.getDiskStoreSize();  

     关于缓存的读取和丢失的记录
         得到缓存读取的命中次数;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int hits = cache.getHitCount();  

         得到内存中缓存读取的命中次数;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int hits = cache.getMemoryStoreHitCount();  

         得到磁盘中缓存读取的命中次数;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int hits = cache.getDiskStoreCount();  

          得到缓存读取的丢失次数;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int hits = cache.getMissCountNotFound();  

         得到缓存读取的已经被销毁的对象丢失次数;

  1. Cache cache = manager.getCache('sampleCache1');   
  2. int hits = cache.getMissCountExpired();  

--------------------------
----------简单例子------------
--------------------------

     实战:
         XML文件格式:

  1.  maxElementsInMemory='10000'  
  2.  eternal='false'  
  3.  timeToIdleSeconds='120'  
  4.  timeToLiveSeconds='120'  
  5.  overflowToDisk='true'  
  6.  diskPersistent='false'  
  7.  diskExpiryThreadIntervalSeconds='120'  
  8.  memoryStoreEvictionPolicy='LRU'  
  9.  />  
  10.              maxElementsInMemory='10000'  
  11. eternal='false'  
  12. overflowToDisk='true'  
  13. timeToIdleSeconds='2'  
  14. timeToLiveSeconds='3'  
  15. memoryStoreEvictionPolicy='LFU'  
  16.  />  


     源码:

  1. import java.io.Serializable;   
  2.   
  3. import net.sf.ehcache.Cache;   
  4. import net.sf.ehcache.CacheManager;   
  5. import net.sf.ehcache.Element;   
  6.   
  7. /**  
  8.  #############################################################################  
  9.  # DESCRIBE ehcache 缓存操作DEMO  
  10.  # AUTHOR    悠~游  
  11.  # DATE      2006-7-10  
  12.  # COMPANY   FLX  
  13.  # PORJECT   ehcache-demo  
  14.  #############################################################################  
  15.  */  
  16.   
  17. public class Demo {   
  18.       
  19.     static CacheManager manager= new CacheManager();   
  20.   
  21.     /**  
  22.      *##############################################################################  
  23.      *   
  24.      * @DESCRIBE      
  25.      * @param args  
  26.      * @throws InterruptedException  
  27.      *                           
  28.      *##############################################################################  
  29.      */  
  30.     public static void main(String[] args) throws InterruptedException {   
  31.           
  32.         String[] cacheNames = manager.getCacheNames();   
  33.         System.out.println('读取的缓存列表为:');   
  34.         for(int i=0;i                     System.out.println('-- '+(i+1)+' '+cacheNames[i]);   
  35.         }   
  36.           
  37.         Cache cache = manager.getCache('cache1');   
  38.         Element element = new Element('key1''value1');   
  39.         cache.put(element);   
  40.           
  41.         element = cache.get('key1');   
  42.         Serializable value = element.getValue();   
  43.         System.out.println('序列化后的值为:'+value.toString());   
  44.   
  45.         element = cache.get('key1');   
  46.         Object value1 = element.getObjectValue();   
  47.         System.out.println('未序列化的值为:'+value1.toString());   
  48.           
  49.         int elementsInMemory = cache.getSize();   
  50.         System.out.println('得到缓存的对象数量:'+elementsInMemory);   
  51.           
  52.         long elementsInMemory1 = cache.getMemoryStoreSize();   
  53.         System.out.println('得到缓存对象占用内存的数量:'+elementsInMemory1);   
  54.           
  55.         long elementsInMemory2 = cache.getDiskStoreSize();   
  56.         System.out.println('得到缓存对对象占用磁盘的数量:'+elementsInMemory2);           
  57.           
  58.         int hits = cache.getHitCount();   
  59.         System.out.println('得到缓存读取的命中次数:'+hits);           
  60.           
  61.         int hits1 = cache.getMemoryStoreHitCount();   
  62.         System.out.println('得到内存中缓存读取的命中次数:'+hits1);           
  63.           
  64.         int hits2 =cache.getDiskStoreHitCount();   
  65.         System.out.println('得到磁盘中缓存读取的命中次数:'+hits2);           
  66.           
  67.         int hits3 = cache.getMissCountNotFound();   
  68.         System.out.println('得到缓存读取的丢失次数:'+hits3);           
  69.           
  70.         int hits4 = cache.getMissCountExpired();   
  71.         System.out.println('得到缓存读取的已经被销毁的对象丢失次数:'+hits4);       
  72.     }   
分享到:
评论
2 楼 jiangm520 2011-08-12  
你自己可以看api 测试哈嘛
1 楼 java_pad 2011-07-28  
cache.getHitCount();
cache.getMemoryStoreHitCount();  
以及一下的方法都没有了么?

相关推荐

    开源缓存包 EHCache 全接触

    **开源缓存包 EHCache 全接触** EHCache 是一个广泛使用的开源 Java 缓存解决方案,它被设计用于提高应用程序的性能和响应速度,通过存储数据到内存中,避免了频繁的数据库访问。EHCache 适用于多种场景,包括 Web ...

    电镀生产线中西门子S7-300 PLC控制程序详解及其应用

    内容概要:本文详细介绍了应用于电镀生产线的西门子S7-300 PLC控制系统的程序设计、硬件配置以及调试过程中积累的实际经验。主要内容涵盖温度控制、条码记录、行车定位、故障排查等方面的技术细节。文中展示了多个关键功能模块的具体实现方法,如PID温度控制、条码数据处理、行车定位判断等,并分享了一些实用的调试技巧和注意事项。此外,还讨论了硬件配置中的重要细节,如模块地址分配、网络拓扑设计等。 适合人群:从事自动化控制领域的工程师和技术人员,尤其是对PLC编程有一定基础的人群。 使用场景及目标:适用于需要深入了解和掌握电镀生产线自动化控制技术的专业人士。目标是帮助读者理解S7-300 PLC在电镀生产线中的具体应用,提高实际项目的开发效率和可靠性。 其他说明:文章不仅提供了详细的程序代码示例,还分享了许多来自一线的真实案例和实践经验,对于解决实际工程中的问题具有很高的参考价值。

    COMSOL仿真中固体超声导波的二维建模与分析:基于汉宁窗调制的200kHz正弦激励信号

    内容概要:本文详细介绍了使用COMSOL Multiphysics进行固体超声导波的二维仿真过程。作者通过建立一个10mm×100mm的铝板模型,应用汉宁窗调制的5周期200kHz正弦激励信号,研究了超声导波在铝板中的传播特性及其模式转换现象。文中涵盖了从模型构建、材料参数设置、网格划分、边界条件设定、激励信号施加到求解设置以及结果分析的完整流程。特别强调了汉宁窗调制的作用,即减少频谱泄漏并提高信号质量。 适合人群:从事超声检测、材料科学、物理学等相关领域的研究人员和技术人员,尤其是那些希望深入了解COMSOL仿真工具及其在超声导波研究中应用的人群。 使用场景及目标:适用于需要精确模拟超声波在固体介质中传播的研究项目,旨在验证理论预测、优化实验设计、评估不同材料和结构对超声波的影响。此外,还可以用于教学目的,帮助学生掌握COMSOL软件的操作方法和超声导波的基础知识。 其他说明:文中提供了详细的参数设置指导和代码片段,有助于读者快速复现仿真过程。同时,作者分享了一些实用技巧,如如何正确设置网格大小、选择合适的窗函数等,以确保仿真结果的准确性。

    离职人员分析仪表盘.xlsx

    离职人员分析仪表盘.xlsx

    基于LabVIEW的多功能虚拟函数信号发生器设计与信号分析

    内容概要:本文详细介绍了如何利用LabVIEW搭建一个多功能的虚拟函数信号发生器及其信号分析功能。首先,文章展示了如何通过LabVIEW的前面板和程序框图创建各种常见波形(如正弦波、方波、三角波等),并深入探讨了波形生成的具体实现方法,包括三角波的周期性和斜率计算、白噪声的生成以及自定义公式的解析。接着,文章讨论了信号处理的关键技术,如自相关分析、频谱分析、积分和微分运算,并提供了具体的实现代码和注意事项。此外,文中还分享了一些实用的经验和技术细节,如避免频谱泄漏的方法、处理多频波的技术、防止内存泄漏的措施等。 适用人群:从事信号处理、电子工程、自动化控制等领域的工作技术人员,尤其是那些熟悉或希望学习LabVIEW编程的人士。 使用场景及目标:适用于实验室环境或教学环境中,用于替代传统物理信号发生器进行信号生成和分析实验。主要目标是提高信号生成和分析的灵活性和便捷性,减少对昂贵硬件设备的依赖。 其他说明:本文不仅提供了详细的代码示例,还分享了许多作者在实践中积累的经验教训,帮助读者更好地理解和应用LabVIEW进行信号处理。

    线性代数_矩阵运算_方程组解释_MIT公开课笔记用途_1742822302.zip

    线性代数

    大雾至尊版V56泛滥无密码.zip

    大雾至尊版V56泛滥无密码.zip

    员工生日关怀方案.doc

    员工生日关怀方案

    试用期情况跟踪表.xls

    试用期情况跟踪表.xls

    员工激励机制与技巧.doc

    员工激励机制与技巧

    员工晋升的自我评价.doc

    员工晋升的自我评价.doc

    基于51单片机protues仿真的多功能婴儿车控制器(仿真图、源代码、AD原理图)

    基于51单片机protues仿真的多功能婴儿车控制器(仿真图、源代码、AD原理图) 该设计为51单片机protues仿真的多功能婴儿车控制器,实现温湿度,音乐,避障,声音监测控制; 1、温湿度检测,婴儿尿湿时会有提醒。 2、声音检测,当婴儿啼哭时也会有提醒。 3、小车避障,小车遇到障碍会后退左转。 4、音乐播放。 5、仿真图、源代码、AD原理图;

    【计算机求职笔试】编程语言基础、数据结构与算法、系统设计等核心考点解析及备考建议介绍了计算机求职笔试

    内容概要:本文档详细介绍了计算机求职笔试的内容与解答,涵盖编程语言基础、数据结构与算法、编程实践与调试、系统设计与软件工程以及综合题型与开放题五个方面。编程语言基础部分强调了语法规则、数据类型与运算符、面向对象编程的核心概念;数据结构与算法部分讲解了常见数据结构(如线性结构、树与图、哈希表)和高频算法(如排序算法、动态规划、递归与回溯);编程实践与调试部分关注编码能力和调试技巧;系统设计与软件工程部分探讨了设计模式、模块化设计、数据库与网络知识;综合题型与开放题部分则提供了场景题和逻辑思维题的示例。最后给出了备考建议,包括知识体系构建、刷题策略和模拟实战的方法。 适合人群:即将参加计算机相关职位笔试的求职者,特别是对编程语言、数据结构、算法设计有初步了解的应届毕业生或初级工程师。 使用场景及目标:①帮助求职者系统复习计算机基础知识,提升笔试通过率;②通过例题和解答加深对编程语言、数据结构、算法的理解;③提供模拟实战环境,提高时间管理和抗压能力。 阅读建议:建议按照文档提供的知识体系顺序进行系统复习,重点攻克高频题型,利用在线平台刷题练习,并结合实际项目经验进行综合应用,同时注意时间管理和抗压能力的训练。

    SecureCRT安装包

    SecureCRT安装包

    物流业人才流失与紧缺现象的对策研究.docx

    物流业人才流失与紧缺现象的对策研究

    招聘渠道费用仪表盘P10.pptx

    招聘渠道费用仪表盘P10.pptx

    五相永磁同步电机Simulink中PI双闭环SVPWM矢量控制建模与优化

    内容概要:本文详细介绍了五相永磁同步电机在Simulink环境下的PI双闭环SVPWM矢量控制建模过程及其优化方法。首先阐述了五相电机相比三相电机的优势,如更小的转矩脉动和更强的容错能力。接着探讨了复杂的Simulink模型搭建,涉及电机本体模块、坐标变换模块、SVPWM模块和PI调节器模块等多个组件。文中提供了具体的Clark变换和PI调节器的代码示例,解释了双闭环控制的工作原理,并详细描述了SVPWM与十扇区划分的具体实现方式。最后展示了模型的性能表现,包括良好的波形质量和快速的动态响应特性。 适合人群:从事电机控制领域的研究人员和技术人员,尤其是对五相永磁同步电机和Simulink建模感兴趣的读者。 使用场景及目标:适用于希望深入了解五相永磁同步电机控制原理并掌握具体实现方法的研究人员和技术人员。目标是帮助读者理解五相电机的特殊性和复杂性,掌握PI双闭环SVPWM矢量控制的建模技巧,提高电机控制系统的设计水平。 其他说明:文章不仅提供了理论知识,还包括了大量的代码片段和实践经验分享,有助于读者更好地理解和应用相关技术。

    员工离职交接表-模板.doc

    员工离职交接表-模板.doc

    离职率高"冰山"下的真相?你知道多少?.docx

    离职率高"冰山"下的真相?你知道多少?

    光伏MPPT中恒定电压法与PID控制结合的技术解析及其应用

    内容概要:本文详细介绍了光伏系统中最大功率点跟踪(MPPT)的一种常见方法——恒定电压法,并探讨了其与PID控制相结合的应用。恒定电压法通过将光伏板的输出电压固定在一个预设值附近,以期接近最大功率点。然而,由于光照和温度的变化,单纯依靠恒定电压法难以精确跟踪最大功率点。因此,引入PID控制器进行动态调整,能够显著提高系统的响应速度和稳定性。文中提供了具体的MATLAB和Python代码示例,展示了如何构建和优化这样的控制系统。同时,还讨论了在Simulink环境中建模时需要注意的关键技术和参数选择。 适合人群:从事光伏系统设计、开发以及维护的技术人员,尤其是希望深入了解MPPT算法原理并掌握具体实现方法的专业人士。 使用场景及目标:适用于需要快速实现MPPT功能的小型光伏系统,特别是在成本受限的情况下。通过学习本文,读者可以掌握恒定电压法的基本概念,学会利用PID控制提升性能的方法,从而更好地应对实际工程项目中的挑战。 其他说明:尽管恒定电压法加上PID控制可以在一定程度上改善MPPT的效果,但它并非最优解。对于更加复杂的环境条件,仍需采用更为先进的算法如电导增量法等。此外,文中提到的一些技巧和注意事项有助于避免常见的错误,确保仿真的准确性。

Global site tag (gtag.js) - Google Analytics