1.@Resource
@Resource 是JDK1.6支持的注解,默认按照名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名,按照名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
@Resource(name="baseDao")
private BaseDao baseDao;
2.@Autowired
@Autowired默认按类型装配(这个注解是属于spring的),默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:
@Autowired() @Qualifier("baseDao")
private BaseDao baseDao;
虽然@Resource和@Autowired都可以来完成依赖注入,但它们之间是有区别的。
a.@Resource默认是按照名称来装配注入的,只有当找不到与名称匹配的bean才会按照类型来装配注入;
b.@Autowired默认是按照类型装配注入的,如果想按照名称来转配注入,则需要结合@Qualifier一起使用;
c.@Resource注解是由JDK提供,而@Autowired是由Spring提供
@Resource的方式;
d. @Resource和@Autowired都可以书写标注在字段或者该字段的setter方法之上
3.@component、@controller、@service、@repository
这四个注解是用来定义bean的,将这其中之一放在一个类上面,就能完成bean的定义。@component是一个泛化的概念,仅仅表示一个bean的组件,可用在任何层次的;而@controller用在控制层的类上面、@service用在service层的类、@repository用在dao层的类上面。就是说@component是通用的,可用于任何层次的类;而@controller、@service、@repository各司其职。使用了这些注解之后,spring会自动创建相应的bean定义对象,并注册到ApplicationContext中,这些类就成了spring要管理的组件
4.@RequestMapping("/dept")
是一个用来处理请求地址映射的注解,可用于类或方法上。
5.@Deprecated
可以用来标记类,方法,属性
如果上述三种元素不再使用,则使用@Deprecated注解
如果代码使用了有@Deprecated注解的类、方法或属性,编译器则会警告
如下,则为注解一个放弃使用的类
@Deprecated
public class MyComponent { }
6.@Override
@Override注解,用来修饰对父类进行重写的方法。如果一个并非重写父类的方法使用这个注解,编译器将提示错误。
实际上在子类中重写父类或接口的方法,@Overide并不是必须的。但是还是建议使用这个注解,在某些情况下,假设你修改了父类的方法的名字,那么之前重写的子类方法将不再属于重写,如果没有@Overide,你将不会察觉到这个子类的方法。有了这个注解修饰,编译器则会提示你这些信息。
7.@SuppressWarnings
@SuppressWarnings用来抑制编译器生成警告信息。
可以修饰的元素为类,方法,方法参数,属性,局部变量
使用场景:当我们一个方法调用了弃用的方法或者进行不安全的类型转换,编译器会生成警告。我们可以为这个方法增加@SuppressWarnings注解,来抑制编译器生成警告。
注意:使用@SuppressWarnings注解,采用就近原则,比如一个方法出现警告,我们尽量使用@SuppressWarnings注解这个方法,而不是注解方法所在的类。虽然两个都能抑制编译器生成警告,但是范围越小越好,因为范围大了,不利于我们发现该类下其他方法的警告信息。