`

spring 3.1中的cache小结

 
阅读更多

spring 3.1中有cache了,下面结合目前网上的一些资料和手册的归纳总结下: 

1 @cache注解 
   在3.1中,都是用注解的了, 
@Cacheable注解可以用在方法或者类级别。当他应用于方法级别的时候,就是如上所说的缓存返回值了。当应用在类级别的时候,这个类的所有方法的返回值都将被缓存。 
 

Java代码   收藏代码
  1. @Cacheable(value = "employee")  
  2. public class EmployeeDAO {  
  3.   
  4.   public Person findEmployee(String firstName, String surname, int age) {  
  5.   
  6.     return new Person(firstName, surname, age);  
  7.   }  
  8.   
  9.   public Person findAnotherEmployee(String firstName, String surname, int age) {  
  10.   
  11.     return new Person(firstName, surname, age);  
  12.   }  
  13. }  


   在上面的代码中,缓存了Person了,命名为employee,缓存的是方法的值, 
@Cacheable注解有三个参数,value是必须的,还有key和condition。第一个参数,也就是value指明了缓存将被存到什么地方。 
    在spring 3.1中,可以使用spel表达式去进行缓存的指定,比如: 

 

Java代码   收藏代码
  1. @Cacheable(value = "employee", key = "#surname")  
  2.   public Person findEmployeeBySurname(String firstName, String surname, int age) {  
  3.   
  4.     return new Person(firstName, surname, age);  
  5.   }  


  这里注意指定的缓存的是根据key=surename。也可以指定表达式 

Java代码   收藏代码
  1. @Cacheable(value = "employee", condition = "#age < 25")  
  2.   public Person findEmployeeByAge(String firstName, String surname, int age) {  
  3.   
  4.     return new Person(firstName, surname, age);  
  5.   }  


   这里指定age<25的才缓存; 
  接下来看下如何应用,比如: 

Java代码   收藏代码
  1. @Test  
  2.   public void testCache() {  
  3.   
  4.     Person employee1 = instance.findEmployee("John""Smith"22);  
  5.     Person employee2 = instance.findEmployee("John""Smith"22);  
  6.   
  7.     assertEquals(employee1, employee2);  
  8.   }  


     这个时候肯定是相等的了,因为用的是缓存。但是如果调用的是 
findEmployeeBySurname方法的话,就一定有点不同了, 

Java代码   收藏代码
  1. @Test  
  2.   public void testCacheOnSurnameAsKey() {  
  3.   
  4.     Person employee1 = instance.findEmployeeBySurname("John""Smith"22);  
  5.     Person employee2 = instance.findEmployeeBySurname("Jack""Smith"55);  
  6.   
  7.     assertEquals(employee1, employee2);  
  8.   }  


  但由于是缓存的是根据surename为key,所以上面结果两个对象却依然是相等的(尽管原本看上去是不同的对象了),所以key的选择一定要小心。 

  继续单元测试: 
 

Java代码   收藏代码
  1. @Test  
  2.   public void testCacheWithAgeAsCondition() {  
  3.   
  4.     Person employee1 = instance.findEmployeeByAge("John""Smith"22);  
  5.     Person employee2 = instance.findEmployeeByAge("John""Smith"22);  
  6.   
  7.     assertEquals(employee1, employee2);  
  8.   }  


    这两个就一样了,因为都是age<25的,都缓存了,指向同一个对象。 


2 取消缓存 
   下面看下如何取消缓存 
  @CacheEvict 

Java代码   收藏代码
  1. @CacheEvict(value = "employee", allEntries = true)  
  2. public void resetAllEntries() {  
  3.   
  4. }  


   使用@CacheEvict去取消缓存, 

@CacheEvict支持如下几个参数: 

value:缓存位置名称,不能为空,同上 

key:缓存的key,默认为空,同上 

condition:触发条件,只有满足条件的情况才会清除缓存,默认为空,支持SpEL 

allEntries:true表示清除value中的全部缓存,默认为false 
  当然,也可以@cahceable和@cacheEvict一起使用,比如: 

Java代码   收藏代码
  1. @CacheEvict(value = "employee", beforeInvocation = true)  
  2. @Cacheable(value = "employee")  
  3. public Person evictAndFindEmployee(String firstName, String surname, int age) {  
  4.   
  5.   return new Person(firstName, surname, age);  
  6. }  


  

Java代码   收藏代码
  1. @Test  
  2. public void testBeforeInvocation() {  
  3.   
  4.   Person employee1 = instance.evictAndFindEmployee("John""Smith"22);  
  5.   Person employee2 = instance.evictAndFindEmployee("John""Smith"22);  
  6.   
  7.   assertNotSame(employee1, employee2);  
  8. }  


   这里的话,先使用@CacheEvict(value = "employee", beforeInvocation = true), 
会先清掉所有缓存,所以asset的结果就不相等了; 
  

3 如何配置 
   .spring-cache 

首先我们来看一下如何使用spring3.1自己的cache, 

需要在命名空间中增加cache的配置 

Java代码   收藏代码
  1. beans xmlns="http://www.springframework.org/schema/beans"    
  2.    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"    
  3.     xmlns:cache="http://www.springframework.org/schema/cache"    
  4.    xsi:schemaLocation="    
  5.            http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd    
  6.           http://www.springframework.org/schema/cache http://www.springframework.org/schema/cache/spring-cache-3.1.xsd">    



Java代码   收藏代码
  1.  <!-- 启用缓存注解功能,这个是必须的,否则注解不会生效,另外,该注解一定要声明在spring主配置文件中才会生效 -->    
  2. <cache:annotation-driven cache-manager="cacheManager"/>    
  3.     
  4.     
  5. <!-- spring自己的换管理器,这里定义了两个缓存位置名称 ,既注解中的value -->    
  6. <bean id="cacheManager" class="org.springframework.cache.support.SimpleCacheManager">    
  7.     <property name="caches">    
  8.        <set>    
  9.           <bean    
  10.                class="org.springframework.cache.concurrent.ConcurrentCacheFactoryBean"    
  11.                 p:name="default" />    
  12.             <bean    
  13.                 class="org.springframework.cache.concurrent.ConcurrentCacheFactoryBean"    
  14.                 p:name="andCache" />    
  15.        </set>      </property>    
  16. </bean>     

 

 

 

@Cacheable(value = "andCache", key ="#surname",condition = "#age < 25 and #firstName=='two' ")  

public Person findEmployeeByAge(String firstName, String surname, int age) {  

分享到:
评论

相关推荐

    Grails 技术精解与Web开发实践【源码+样章】----下载不扣分,回帖加1分,欢迎下载,童叟无欺

    1.6 本章小结 4 第一篇 入门篇 第2章 Hello Grails 6 2.1 Grails的安装 6 2.1.1 JDK的安装与配置 6 2.1.2 Grails的安装 7 2.2 创建Grails工程 8 2.3 Grails的MVC架构 11 2.4 Scaffold应用程序 14 2.5 开发工具的...

    mybatis学习文档资料

    - **2.4 resultType和resultMap实现一对一查询小结**:比较两种映射方式的特点和适用场景。 ##### (二)一对多查询 - **3.1 需求**:查询订单及其对应的订单详情信息。 - **3.2 SQL语句**:SELECT * FROM Orders ...

    mybatis高级映射

    **小结**: 使用 `resultType` 进行一对一映射适用于查询结果和对象属性一一对应的情况;使用 `resultMap` 可以处理更复杂的映射逻辑,如嵌套对象。 **1.2 一对多映射** **需求**: 查询订单信息,并关联查询订单...

    scratch少儿编程逻辑思维游戏源码-城堡战争.zip

    scratch少儿编程逻辑思维游戏源码-城堡战争.zip

    【Go语言编程】大厂Go工程师面试题集锦:涵盖并发、网络、数据库及算法设计要点

    内容概要:本文档汇集了来自字节跳动、腾讯、金山WPS、跟谁学和百度等大厂的Go工程师面试题,涵盖广泛的技术领域。主要包括Go语言特性(如goroutine调度、channel机制)、操作系统(进程间通信、线程调度)、计算机网络(TCP/IP协议栈、HTTP协议)、数据结构与算法(排序算法、LRU缓存)、数据库(MySQL索引优化、Redis内部机制)、分布式系统(负载均衡、服务发现)等方面的知识点。通过这些问题,不仅考察应聘者的理论基础,还测试其实际项目经验和技术深度。 适合人群:有一定Go语言编程经验和计算机基础知识的开发者,特别是准备应聘互联网大厂的中级及以上水平的后端工程师或全栈工程师。 使用场景及目标:①帮助求职者全面复习Go语言及其相关领域的核心概念;②为面试官提供有价值的参考题目,确保候选人具备解决复杂问题的能力;③指导工程师深入理解并掌握企业级应用开发所需的关键技能。 阅读建议:由于题目覆盖面广且难度较高,建议读者结合自身情况选择重点复习方向,同时配合实际编码练习加深理解。对于每个知识点,不仅要记住答案,更要理解背后的原理,这样才能在面试中灵活应对各种变体问题。

    scratch少儿编程逻辑思维游戏源码-堡垒之夜(吃鸡游戏).zip

    scratch少儿编程逻辑思维游戏源码-堡垒之夜(吃鸡游戏).zip

    少儿编程scratch项目源代码文件案例素材-派.zip

    少儿编程scratch项目源代码文件案例素材-派.zip

    scratch少儿编程逻辑思维游戏源码-Scratch 冒险.zip

    scratch少儿编程逻辑思维游戏源码-Scratch 冒险.zip

    2025 飞特舵机, Arduino版本

    2025 飞特舵机, Arduino版本

    scratch少儿编程逻辑思维游戏源码-躲避.zip

    scratch少儿编程逻辑思维游戏源码-躲避.zip

    PFC5.0纤维混凝土三点弯曲模拟:参数化建模与实验分析

    内容概要:本文详细介绍了利用PFC5.0进行纤维混凝土三点弯曲模拟的方法。首先,作者展示了如何通过定义纤维的体积含量、长度、半径和刚度等关键参数来构建纤维网络。接着,描述了三点弯曲加载的具体实现方式,包括加载速率控制和终止条件设定。最后,提供了后处理方法,如绘制并导出力-位移曲线图,以便于分析材料破坏机制。文中还给出了若干实用建议,如纤维半径的选择范围、加载速率的初始值以及不同类型纤维的接触模型选择。 适合人群:从事材料科学尤其是混凝土材料研究的专业人士,以及对离散元法和数值模拟感兴趣的科研工作者。 使用场景及目标:适用于希望深入了解纤维混凝土力学性能的研究人员,旨在帮助他们掌握PFC5.0软件的操作技巧,优化模拟参数设置,提高实验效率。 其他说明:文中提供的代码片段可以直接应用于实际项目中,同时附带了一些实践经验分享,有助于初学者快速入门并避免常见错误。

    少儿编程scratch项目源代码文件案例素材-生存V1(有BAG).zip

    少儿编程scratch项目源代码文件案例素材-生存V1(有BAG).zip

    少儿编程scratch项目源代码文件案例素材-披萨机器人.zip

    少儿编程scratch项目源代码文件案例素材-披萨机器人.zip

    少儿编程scratch项目源代码文件案例素材-气球滑雪板.zip

    少儿编程scratch项目源代码文件案例素材-气球滑雪板.zip

    少儿编程scratch项目源代码文件案例素材-使命召唤(苏联插旗).zip

    少儿编程scratch项目源代码文件案例素材-使命召唤(苏联插旗).zip

    可跨平台移植的模拟IIC实战项目STM32F407-TestIIC

    1. GPIO模拟I2C 实战项目,根据正点原子 STM32F407ZGT6 进行更改; 2. 可适配STM32、GD32、HC32等MCU;

    scratch少儿编程逻辑思维游戏源码-百米冲刺.zip

    scratch少儿编程逻辑思维游戏源码-百米冲刺.zip

    【蓝桥杯竞赛】历年试题精选与备考资源汇总:编程算法及硬件单片机试题解析与练习指导

    内容概要:本文档汇总了蓝桥杯历年试题及练习资源,涵盖编程类试题精选、硬件与单片机试题、练习资源与题库以及备考建议。编程类试题精选包括基础算法题(如数组求和、质因数分解)、经典算法案例(如最大子序列和、兰顿蚂蚁模拟)和数据结构应用(如字符全排列)。硬件与单片机试题主要涉及客观题考点,如BUCK电路和电源设计。练习资源与题库部分介绍了真题平台(如Dotcpp、CSDN专题)和专项训练包(如Python题库、Java百题集、C++真题解析)。备考建议分为分阶段练习(新手阶段、进阶提升)和模拟实战(如使用Dotcpp估分系统进行限时训练),强调按年份和组别分类练习,强化代码实现与调试能力。; 适合人群:准备参加蓝桥杯竞赛的学生及编程爱好者。; 使用场景及目标:①针对不同编程语言和难度级别的题目进行专项训练;②通过历年真题和模拟实战提高解题速度和准确性;③掌握算法设计、数据结构应用及硬件基础知识。; 阅读建议:此文档提供了丰富的试题和练习资源,建议根据自身水平选择合适的题目进行练习,并结合真题平台的估分系统和社区开源代码进行对比优化,逐步提升编程能力和竞赛水平。

    30kW储能PCS原理图设计:量产设计的关键要素与优化策略

    内容概要:本文详细介绍了30kW储能PCS(电力转换系统)原理图的设计要点及其量产化过程中需要注意的技术细节。首先阐述了储能PCS的基本概念和重要性,接着深入探讨了主拓扑结构的选择,特别是双级式结构的优势以及关键组件如IGBT的驱动时序配置。随后讨论了控制算法的智能化改进,包括加入前馈补偿以提高系统的稳定性。此外,还强调了EMC设计、PCB布局、元件选择等方面的注意事项,并分享了一些实际生产中遇到的问题及解决方案。最后提到了自动化测试方法和散热管理策略,确保产品在各种环境下的可靠运行。 适合人群:从事储能系统设计、电力电子产品研发的工程师和技术人员。 使用场景及目标:帮助读者掌握30kW储能PCS从原理图设计到量产实施的全流程关键技术,提升产品的性能和可靠性,避免常见错误。 其他说明:文中提供了具体的代码片段和实践经验,有助于理解和应用相关理论。

Global site tag (gtag.js) - Google Analytics