首页 > 编程知识 正文

spring注解大全,java多线程

时间:2023-05-06 07:23:20 阅读:17522 作者:4436

从3.1开始,Spring引入了对Cache的支持。 其使用方法和原理类似于Spring对事务管理的支持。 Spring Cache作用于方法,其中心思想是在调用缓存方法时将方法参数和返回结果作为键值对保存在缓存中,直到下一次使用相同的参数调用该方法时才执行该方法,而不是缓存因此,使用Spring Cache时,可以确保缓存的方法对同一方法参数具有相同的返回结果。

要使用Spring Cache,必须执行以下两项操作:

您可以将Spring配置为使用缓存支持Cache,也可以将Spring配置为支持事务管理。 此外,有两种方法:基于注释和基于XML的设置。 首先,让我们看看基于注释的方法。

1基于注释的支持Spring为支持Spring Cache提供了一些评论。 其核心主要是@Cacheable和@CacheEvict。 使用@Cacheable标记的方法缓存在执行后返回Spring Cache的结果,而使用@CacheEvict标记的方法在执行该方法之前或之后删除Spring Cache的某些元素。 接下来,我们将详细介绍Spring为支持基于注释的Cache而提供的一些注释。

1.1 @Cacheable @Cacheable可以标记为一个方法,也可以标记为一个类。 如果方法标记,则方法支持缓存;如果类标记,则该类的所有方法都支持缓存。 对于支持缓存的方法,Spring在调用后缓存返回值。 这样,下次使用相同参数执行方法时,可以直接从缓存中检索结果,而无需再次执行该方法。 Spring在缓存方法的返回值时以键值对缓存。 值是方法的返回值。 对于密钥,Spring支持两个策略:默认策略和自定义策略。 这将在后面叙述。 请注意,如果在对象内部调用支持缓存的方法,则不会启动缓存功能。 @Cacheable可以指定三个属性: value、key和condition。

参数说明examplevalue缓存的名称在spring配置文件中定义,并且必须至少指定一个。 例如:

@cacheable(value=”mycache”)

@cacheable(value=() cache1)、() cache2) ) key缓存中的key可以为空。 如果指定用SpEL表达式编写,否则缺省情况下将在方法的所有参数中组合。 @cacheable(value=”testcache”,key=”#userName”) ) condition缓存条件可以为空,用SpEL编写,返回true或false,然后返回trurue @Cacheable(value="testcache ",condition=”#userName.length ) )1.1.1 value属性必须指定cache名称,并且当前方法的返回值为

@cacheable('cache1)//Cache是发生在cache1上的publicuserfind(integerid ) { returnnull; }@cacheable((cache1(,cache2) )//Cache是在cache1和cache2中发生的publicuserfind ) integerid ) { returnnull; }1.1. 2使用key属性自定义key key属性用于指定返回Spring缓存方法结果时的相应key。 此属性支持SpringEL表达式。 如果未指定此属性,Spring将使用默认策略生成密钥。 现在,我们先来看看定制战略。 稍后我们将单独讨论默认策略。

自定义策略是指可以在Spring的EL表达式中指定密钥。 其中的EL表达式可以使用方法参数及其相应的属性。 使用方法参数时,可以直接使用“#参数名称”或“#p参数索引”。 下面是一些使用参数作为key的示例。

/*** key是指传递时的参数**/@cacheable(value='users ',key='#id ' ) publicuserfind (integer id ) { returnnull //第一个参数@cacheable(value='users ',key='#p0 ' ) publicuserfind(integerid ) { returnnull; User的id值@cacheable(value='users ',key='#user.id ' ) publicuserfind(useruser ) { returnnull; //表示第一个参数的id属性值@cacheable(value='users ',key='#p0.id ' ) publicuserfind (use )

r user) { returnnull; }

除了上述使用方法参数作为key之外,Spring还为我们提供了一个root对象可以用来生成key。通过该root对象我们可以获取到以下信息。

属性名称描述示例methodName当前方法名#root.methodNamemethod当前方法#root.method.nametarget当前被调用的对象#root.targettargetClass当前被调用的对象的class#root.targetClassargs当前方法参数组成的数组#root.args[0]caches当前被调用的方法使用的Cache#root.caches[0].name

当我们要使用root对象的属性作为key时我们也可以将“#root”省略,因为Spring默认使用的就是root对象的属性。如:

// key值为: user中的name属性的值 @Cacheable(value={"users", "xxx"}, key="caches[1].name") public User find(User user) { returnnull; } 1.1.3  condition属性指定发生的条件

有的时候我们可能并不希望缓存一个方法所有的返回结果。通过condition属性可以实现这一功能。condition属性默认为空,表示将缓存所有的调用情形。其值是通过SpringEL表达式来指定的,当为true时表示进行缓存处理;当为false时表示不进行缓存处理,即每次调用该方法时该方法都会执行一次。如下示例表示只有当user的id为偶数时才会进行缓存。

// 根据条件判断是否缓存 @Cacheable(value={"users"}, key="#user.id", condition="#user.id%2==0") public User find(User user) { System.out.println("find user by user " + user); return user; } 1.2     @CachePut

 在支持Spring Cache的环境下,对于使用@Cacheable标注的方法,Spring在每次执行前都会检查Cache中是否存在相同key的缓存元素,如果存在就不再执行该方法,而是直接从缓存中获取结果进行返回,否则才会执行并将返回结果存入指定的缓存中。@CachePut也可以声明一个方法支持缓存功能。与@Cacheable不同的是使用@CachePut标注的方法在执行前不会去检查缓存中是否存在之前执行过的结果,而是每次都会执行该方法,并将执行结果以键值对的形式存入指定的缓存中。

//@CachePut也可以标注在类上和方法上。使用@CachePut时我们可以指定的属性跟@Cacheable是一样的。 @CachePut("users")//每次都会执行方法,并将结果存入指定的缓存中 public User find(Integer id) { returnnull; } 1.3     @CacheEvict

       @CacheEvict是用来标注在需要清除缓存元素的方法或类上的。当标记在一个类上时表示其中所有的方法的执行都会触发缓存的清除操作。@CacheEvict可以指定的属性有value、key、condition、allEntries和beforeInvocation。其中value、key和condition的语义与@Cacheable对应的属性类似。即value表示清除操作是发生在哪些Cache上的(对应Cache的名称);key表示需要清除的是哪个key,如未指定则会使用默认策略生成的key;condition表示清除操作发生的条件。下面我们来介绍一下新出现的两个属性allEntries和beforeInvocation。

1.3.1  allEntries属性

        allEntries是boolean类型,表示是否需要清除缓存中的所有元素。默认为false,表示不需要。当指定了allEntries为true时,Spring Cache将忽略指定的key。有的时候我们需要Cache一下清除所有的元素,这比一个一个清除元素更有效率。

@CacheEvict(value="users", allEntries=true) public void delete(Integer id) { System.out.println("delete user by id: " + id); } 1.3.2  beforeInvocation属性       

        清除操作默认是在对应方法成功执行之后触发的,即方法如果因为抛出异常而未能成功返回时也不会触发清除操作。使用beforeInvocation可以改变触发清除操作的时间,当我们指定该属性值为true时,Spring会在调用该方法之前清除缓存中的指定元素。

@CacheEvict(value="users", beforeInvocation=true) public void delete(Integer id) { System.out.println("delete user by id: " + id); }

        其实除了使用@CacheEvict清除缓存元素外,当我们使用Ehcache作为实现时,我们也可以配置Ehcache自身的驱除策略,其是通过Ehcache的配置文件来指定的。由于Ehcache不是本文描述的重点,这里就不多赘述了,想了解更多关于Ehcache的信息,请查看我关于Ehcache的专栏。

1.4     @Caching

       @Caching注解可以让我们在一个方法或者类上同时指定多个Spring Cache相关的注解。其拥有三个属性:cacheable、put和evict,分别用于指定@Cacheable、@CachePut和@CacheEvict。

@Caching(cacheable = @Cacheable("users"), evict = { @CacheEvict("cache2"), @CacheEvict(value = "cache3", allEntries = true) }) public User find(Integer id) { returnnull; } 1.5     使用自定义注解

       Spring允许我们在配置可缓存的方法时使用自定义的注解,前提是自定义的注解上必须使用对应的注解进行标注。如我们有

如下这么一个使用@Cacheable进行标注的自定义注解。

@Target({ElementType.TYPE, ElementType.METHOD})@Retention(RetentionPolicy.RUNTIME)@Cacheable(value="users")public @interface MyCacheable {}

那么在我们需要缓存的方法上使用@MyCacheable进行标注也可以达到同样的效果。

@MyCacheable public User findById(Integer id) { System.out.println("find user by id: " + id); User user = new User(); user.setId(id); user.setName("Name" + id); return user; } 参数解释examplevalue缓存的名称,在 spring 配置文件中定义,必须指定至少一个例如:
@Cacheable(value=”mycache”)
@Cacheable(value={”cache1”,”cache2”}key缓存的 key,可以为空,如果指定要按照 SpEL 表达式编写,如果不指定,则缺省按照方法的所有参数进行组合@Cacheable(value=”testcache”,key=”#userName”)condition缓存的条件,可以为空,使用 SpEL 编写,返回 true 或者 false,只有为 true 才进行缓存@Cacheable(value=”testcache”,condition=”#userName.length()>2”)

 

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。