注解用法

 

spring 注解方式配置(简化XML配置文件)
   1)组件自动扫描功能
    首先需要在applicationContext.xml中添加<context:component-scan/>
   a.扫描Bean组件的注解,替代xml中的<bean>元素的定义。
     @Service 用于Service业务组件
     @Control 用于Action控制组件
     @Respository 用于DAO数据访问组件
     @Component 用于其他组件
     Bean组件扫描到容器后,默认名字为类名(首字母小写)
 如果需要自定义名称可以使用@Service("id名")
     b.依赖注入的注解标记
    @Resource 按名称@Resource(name="id名")
       @AutoWired 按名称
        @Autowired
    	@Qualifier("id名")
     c.其他注解
     	@Scope 等价于<bean scope="">
     	@PostConstruct 等价于<bean init-method="">
     	@PreDestroy 等价于<bean destroy-method="">

 

 

 

 

 

注解详解:

 

一、java内置注解- J0 y. E* ?9 c1 C6 R' t5 Z& l
0 E( x( H$ S+ Y* @
     1、@Target 表示该注解用于什么地方,可能的 ElemenetType 参数包括:  
            ElemenetType.CONSTRUCTOR   构造器声明  / ^& b9 Z* h. g& Y, t- A+ Y7 [9 \
            ElemenetType.FIELD   域声明(包括 enum 实例)  
            ElemenetType.LOCAL_VARIABLE   局部变量声明  5 O! ?- S3 S0 y" G) z
            ElemenetType.METHOD   方法声明  ! V! b. V4 f5 X' a/ c, b, ?+ W1 K/ g
            ElemenetType.PACKAGE   包声明  2 S' f+ P  ?* c+ X
            ElemenetType.PARAMETER   参数声明  6 s! Q9 J& @! x
            ElemenetType.TYPE   类,接口(包括注解类型)或enum声明
    2、@Retention 表示在什么级别保存该注解信息。可选的 RetentionPolicy 参数包括:  
         RetentionPolicy.SOURCE   注解将被编译器丢弃  4 P' T+ s1 {9 }
           RetentionPolicy.CLASS   注解在class文件中可用,但会被VM丢弃  
           RetentionPolicy.RUNTIME   VM将在运行期也保留注释,因此可以通过反射机制读取注解的信息。/ L1 h" G6 R! D; W/ i
    & s: U6 X& F) e/ m9 F/ Z
     3、@Documented 将此注解包含在 javadoc 中
H& h3 g# |8 R  U/ b  x
     4、@Inherited 允许子类继承父类中的注解' {5 |# f. y* ~" _0 M* L# L9 D

   5、@Deprecated  表示当前元素是不赞成使用的。
a3 y, A+ `! n% M" U* g
     6、@Override  表示当前方法是覆盖父类的方法。; X  `- A2 x# Q/ [+ @; }

     7、@SuppressWarnings  表示关闭一些不当的编译器警告信息。; B% P/ U: N& r! O0 L% t
6 J; A- e$ s" H8 E' ]6 ~
5 q* [! g  {* q% t8 r. B

二、Spring内置注解  K) e' G$ {/ u% d4 Y9 c

     1、@Autowired注解/ {% s9 p8 b$ i5 N2 n1 N
% p) ^! B7 _9 W  z2 r" H
          采用byType的方法自动装配。可以应用在类的成员变量、成员方法和构造子。默认情况下使用@Autowired注解进行自动注入时,Spring容器中匹配的候选Bean数目必须有且仅有一个。可以设置required=false让其成为可选的。当存在多个类型一致的bean时,可以用@Qualifier注解来明确指定要装配的bean。( [% J& ?1 f( K7 D6 P

 s( o1 _: N
     2、@Qualifier注解% ^: a/ J- |5 u1 X5 ?2 _( }, v

           @Qualifier("Bean的名称")  指定注入Bean的名称。只能用于类的成员变量、方法的参数和构造子的参数。如果它与@Autowired联合使用,则自动装配的策略就变为byName了。
  注解使用范例:

  1. public class Person {
  2.         private Long id;
  3.         private String name;
  4.         private Address address;
  5.         
  6.         public Person(){
  7.                 
  8.         }
  9.         
  10.         public Person(Long id, String name){
  11.                 this.id = id;
  12.                 this.name = name;
  13.         }

  14.         @Autowired(required=false)
  15.         public void setAddress(@Qualifier("address2")Address address) {
  16.                 this.address = address;
  17.         }
  18. }
复制代码
  1. <!-- 通过注解定义bean。默认同时也通过注解自动注入 -->
  2. <context:component-scan base-package="com.cjm"/>

  3. <bean id="address1" class="model.Address" p:city="gz1" p:zipCode="111"/>
  4. <bean id="address2" class="model.Address" p:city="gz2" p:zipCode="222"/>

  5. <bean id="person" class="model.Person">
  6.         <constructor-arg index="0" ="111"/>
  7.         <constructor-arg index="1" ="cjm"/>
  8. </bean>
复制代码

自定义限定符注解:

  1. @Target({ElementType.FIELD, ElementType.PARAMETER})
  2. @Retention(RetentionPolicy.RUNTIME)
  3. @Qualifier
  4. public @interface MyQulifier {
  5.         String ();
  6. }
复制代码
  1. public class Person {
  2.         private Long id;
  3.         private String name;
  4.         private Address address;
  5.         
  6.         public Person(){
  7.                 
  8.         }
  9.         
  10.         public Person(Long id, String name){
  11.                 this.id = id;
  12.                 this.name = name;
  13.         }

  14.         @Autowired
  15.         public void setAddress(@MyQulifier("a2")Address address) {
  16.                 this.address = address;
  17.         }
  18. }
复制代码
  1. <bean id="address1" class="model.Address" p:city="gz1" p:zipCode="111">
  2.         <qualifier type="annotation.MyQulifier" ="a1"/>
  3. </bean>

  4. <bean id="address2" class="model.Address" p:city="gz2" p:zipCode="222">
  5.         <qualifier type="annotation.MyQulifier" ="a2"/>
  6. </bean>
复制代码

3、@Component注解

         @Component("Bean的名称")  通过注解标注一个类为受管Bean。默认情况下通过@Component定义的Bean都是singleton的,如果需要使用其它作用范围的Bean,可以通过@Scope注释来达到目标。
     4、@Scope注解1 Q  d& T  l1 K' q) d

          @Scope("Bean的作用范围")  通过@Scope注解为受管指定作用域。BeanBean的作用范围有:singleton、prototype等。
]/ u' O0 a$ l& l; x/ r' u
     5、@Controller注解% |1 \7 p5 |5 M' ?' M

Q& e/ \0 E
* x7 f; i& R& @
     6、@Service注解# C* w6 C$ C' c3 U4 Y
; W  ^) W# f6 y4 N) @% y

Q& P2 h* I( Y* W4 R
     7、@Repository注解
?9 e& ]" \+ l( O5 Q

三、JSR-250规范的注解(需要common-annotations.jar包的支持)$ p2 ~4 Q+ a) Z- H4 k) j1 g/ B

     1、@Resource注解
2 V- F) t3 h, z) q
          @Resource(name="person")  name属性用于指定注入的Bean的名称。# S2 e9 K0 X' g
9 {+ n6 M% g$ {0 F
          @Resource(type=Person.class)  type属性用于指定注入的Bean的类型。
@7 q- j! R$ v; |9 `; P
% M" a# X  H4 R: ~/ Q/ V! S% h

     2、@PostContsuct注解

          用于指定受管Bean的初始化方法,作用与Bean的init-method属性类似。) ?/ M" E! @4 M/ y- R! |2 l
3 ?/ N3 i' }% l) q4 O! X
/ k8 v( ?1 r- O) ^6 g
$ a+ h+ E  ]: m( K% ^& v
     3、@PreDestory注解: v- B- t3 I1 Q5 F7 ?
/ q8 v1 d9 O( \3 B. L9 P0 j
          用于指定受管Bean的析构方法,作用与Bean的destory-method属性类似。

你可能感兴趣的:(注解)