注解用法
?
? ?? ?? ?? ?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了。
??注解使用范例:public class Person {
复制代码
? ? ? ? private Long id;
? ? ? ? private String name;
? ? ? ? private Address address;
? ? ? ??
? ? ? ? public Person(){
? ? ? ? ? ? ? ??
? ? ? ? }
? ? ? ??
? ? ? ? public Person(Long id, String name){
? ? ? ? ? ? ? ? this.id = id;
? ? ? ? ? ? ? ? this.name = name;
? ? ? ? }
? ? ? ? @Autowired(required=false)
? ? ? ? public void setAddress(@Qualifier("address2")Address address) {
? ? ? ? ? ? ? ? this.address = address;
? ? ? ? }
}<!-- 通过注解定义bean。默认同时也通过注解自动注入 -->
复制代码
<context:component-scan base-package="com.cjm"/>
<bean id="address1" p:city="gz1" p:zipCode="111"/>
<bean id="address2" p:city="gz2" p:zipCode="222"/>
<bean id="person" ="111"/>
? ? ? ? <constructor-arg index="1" ="cjm"/>
</bean>自定义限定符注解:
@Target({ElementType.FIELD, ElementType.PARAMETER})
复制代码
@Retention(RetentionPolicy.RUNTIME)
@Qualifier
public @interface MyQulifier {
? ? ? ? String ();
}public class Person {
复制代码
? ? ? ? private Long id;
? ? ? ? private String name;
? ? ? ? private Address address;
? ? ? ??
? ? ? ? public Person(){
? ? ? ? ? ? ? ??
? ? ? ? }
? ? ? ??
? ? ? ? public Person(Long id, String name){
? ? ? ? ? ? ? ? this.id = id;
? ? ? ? ? ? ? ? this.name = name;
? ? ? ? }
? ? ? ? @Autowired
? ? ? ? public void setAddress(@MyQulifier("a2")Address address) {
? ? ? ? ? ? ? ? this.address = address;
? ? ? ? }
}<bean id="address1" p:city="gz1" p:zipCode="111">
复制代码
? ? ? ? <qualifier type="annotation.MyQulifier" ="a1"/>
</bean>
<bean id="address2" p:city="gz2" p:zipCode="222">
? ? ? ? <qualifier type="annotation.MyQulifier" ="a2"/>
</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属性类似。