SpringCloud的注解:汇总篇
使⽤注解之前要开启⾃动扫描功能,如下配置中base-package为需要扫描的包(含⼦包):
1<context:component-scan base-package="cn.test"/>
@Configuration把⼀个类作为⼀个IoC容器,它的某个⽅法头上如果注册了@Bean,就会作为这个Spring容器中的Bean。@Scope注解 作⽤域
@Lazy(true) 表⽰延迟初始化
@Service⽤于标注业务层组件、
@Controller⽤于标注控制层组件(如struts中的action)
@Repository⽤于标注数据访问组件,即DAO组件。
@Component泛指组件,当组件不好归类的时候,我们可以使⽤这个注解进⾏标注。
@Scope⽤于指定scope作⽤域的(⽤在类上)
---------------jsr250----
@PostConstruct⽤于指定初始化⽅法(⽤在⽅法上)
@PreDestory⽤于指定销毁⽅法(⽤在⽅法上)
@Resource 默认按名称装配,当不到与名称匹配的bean才会按类型装配。
----------
@DependsOn:定义Bean初始化及销毁时的顺序
@Primary:⾃动装配时当出现多个Bean候选者时,被注解为@Primary的Bean将作为⾸选者,否则将抛出异常
@Autowired 默认按类型装配,如果我们想使⽤按名称装配,可以结合@Qualifier注解⼀起使⽤。如下:
@Autowired @Qualifier("personDaoBean") 存在多个实例配合使⽤
@PostConstruct 初始化注解
@PreDestroy 摧毁注解 默认 单例 启动就加载??
@Async异步⽅法调⽤,需要添加以下代码:
1 2 3 4 5<bean id="taskExecutor"class="org.urrent.ThreadPoolTaskExecutor"> <property name="corePoolSize"value="10"/>
<property name="maxPoolSize"value="300"/>
</bean>
<task:annotation-driven/>
为了让@Async注解能够⽣效,还需要在Spring Boot的主程序中配置@EnableAsync 在Spring中,基于@Async标注的⽅法,称之为异步⽅法;
这些⽅法将在执⾏的时候,将会在独⽴的线程中被执⾏,
调⽤者⽆需等待它的完成,
即可继续其他的操作。
@Async所修饰的函数不要定义为static类型,这样异步调⽤不会⽣效
spring ioc注解@ComponentScan(basePackages = "")
@EnableAutoConfiguration
@SpringBootApplication
@PropertySource({"classpath:application.properties", "classpath:xzc.properties"})
@ImportResource("l")
@EnableRedisHttpSession
@EnableAspectJAutoProxy
@EnableCaching
@EnableAsync
@Configuration
@EnableScheduling 启动定时任务
概述
注释配置相对于 XML 配置具有很多的优势:
它可以充分利⽤ Java 的反射机制获取类结构信息,这些信息可以有效减少配置的⼯作。如使⽤ JPA 注释配置 ORM 映射时,我们就不需要指定 PO 的属性名、类型等信息,如果关系表字段和 PO 属性名、类型都⼀致,您甚⾄⽆需编写任务属性映射信息——因为这些信息都可以通过 Java 反射机制获取。
注释和 Java 代码位于⼀个⽂件中,⽽ XML 配置采⽤独⽴的配置⽂件,⼤多数配置信息在程序开发完成后都不会调整,如果配置信息和 Java 代码放在⼀起,有助于增强程序的内聚性。⽽采⽤独⽴的 XML 配置⽂件,程序员在编写⼀个功能时,往往需要在程序⽂件和配置⽂件中不停切换,这种思维上的不连贯会降低开发效率。
因此在很多情况下,注释配置⽐ XML 配置更受欢迎,注释配置有进⼀步流⾏的趋势。Spring 2.5 的⼀⼤增强就是引⼊了很多注释类,现在您已经可以使⽤注释配置完成⼤部分 XML 配置的功能。在这篇⽂章⾥,我们将向您讲述使⽤注释进⾏ Bean 定义和依赖注⼊的内容。
原来我们是怎么做的
在使⽤注释配置之前,先来回顾⼀下传统上是如何配置 Bean 并完成 Bean 之间依赖关系的建⽴。下⾯是 3 个类,它们分别是 Office、Car 和 Boss,这 3 个类需要在 Spring 容器中配置为 Bean:
Office 仅有⼀个属性:
清单 1. Office.java
package com.baobaotao;
public class Office {
private String officeNo =”001”;
//省略 get/setter
@Override
public String toString() {
return "officeNo:" + officeNo;
}
}
Car 拥有两个属性:
清单 2. Car.java
package com.baobaotao;
public class Car {
private String brand;
private double price;
// 省略 get/setter
@Override
public String toString() {
return "brand:" + brand + "," + "price:" + price;
}
}
Boss 拥有 Office 和 Car 类型的两个属性:
清单 3. Boss.java
package com.baobaotao;
public class Boss {
private Car car;
private Office office;
// 省略 get/setter
@Override
public String toString() {
return "car:" + car + "\n" + "office:" + office;
}
}
我们在 Spring 容器中将 Office 和 Car 声明为 Bean,并注⼊到 Boss Bean 中:下⾯是使⽤传统 XML 完成这个⼯作的配置⽂件l:
清单 4. l 将以上三个类配置成 Bean
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="/schema/beans"
xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/schema/beans
/schema/beans/spring-beans-2.5.xsd">
<bean id="boss" class="com.baobaotao.Boss">
<property name="car" ref="car"/>
<property name="office" ref="office" />
</bean>
<bean id="office" class="com.baobaotao.Office">
<property name="officeNo" value="002"/>
</bean> <bean id="car" class="com.baobaotao.Car" scope="singleton">
<property name="brand" value=" 红旗 CA72"/>
<property name="price" value="2000"/> </bean>
</beans>
当我们运⾏以下代码时,控制台将正确打出 boss 的信息:
清单 5. 测试类:AnnoIoCTest.java
import t.ApplicationContext;
import t.support.ClassPathXmlApplicationContext;
public class AnnoIoCTest {
public static void main(String[] args) {
String[] locations = {"l"};
ApplicationContext ctx =
new ClassPathXmlApplicationContext(locations);
Boss boss = (Boss) Bean("boss");
System.out.println(boss);
}
}
这说明 Spring 容器已经正确完成了 Bean 创建和装配的⼯作。
使⽤ @Autowired 注释
Spring 2.5 引⼊了 @Autowired 注释,它可以对类成员变量、⽅法及构造函数进⾏标注,完成⾃动装配的⼯作。来看⼀下使
⽤@Autowired 进⾏成员变量⾃动注⼊的代码:
清单 6. 使⽤ @Autowired 注释的 Boss.java
package com.baobaotao;
import org.springframework.beans.factory.annotation.Autowired;
public class Boss {
@Autowired
private Car car;
@Autowired
private Office office;
…
}
Spring 通过⼀个 BeanPostProcessor 对 @Autowired 进⾏解析,所以要让@Autowired 起作⽤必须事先在 Spring 容器中声
明AutowiredAnnotationBeanPostProcessor Bean。
清单 7. 让 @Autowired 注释⼯作起来
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="/schema/beans"
xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/schema/beans
/schema/beans/spring-beans-2.5.xsd">
<!-- 该 BeanPostProcessor 将⾃动起作⽤,对标注 @Autowired 的 Bean 进⾏⾃动注⼊ -->
<bean class="org.springframework.beans.factory.annotation. AutowiredAnnotationBeanPostProcessor"/>
<!-- 移除 boss Bean 的属性注⼊配置的信息 -->
<bean id="boss" class="com.baobaotao.Boss"/>
<bean id="office" class="com.baobaotao.Office">
<property name="officeNo" value="001"/>
</bean>
<bean id="car" class="com.baobaotao.Car" scope="singleton">
<property name="brand" value=" 红旗 CA72"/>
<property name="price" value="2000"/>
</bean>
</beans>
这样,当 Spring 容器启动时,AutowiredAnnotationBeanPostProcessor 将扫描 Spring 容器中所有 Bean,当发现 Bean 中拥
有@Autowired 注释时就到和其匹配(默认按类型匹配)的 Bean,并注⼊到对应的地⽅中去。
按照上⾯的配置,Spring 将直接采⽤ Java 反射机制对 Boss 中的 car 和 office 这两个私有成员变量进⾏⾃动注⼊。所以对成员变量使⽤@Autowired后,您⼤可将它们的 setter ⽅法(setCar() 和 setOffice())从 Boss 中删除。
当然,您也可以通过 @Autowired 对⽅法或构造函数进⾏标注,来看下⾯的代码:
清单 8. 将 @Autowired 注释标注在 Setter ⽅法上
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论