Spring注解@Component、@Repository、@Service、@Controller区别

来源:互联网 发布:mac尘埃3汉化 编辑:程序博客网 时间:2024/06/15 00:53

Spring 2.5 中除了提供 @Component 注释外,还定义了几个拥有特殊语义的注释,它们分别是:@Repository@Service  @Controller。在目前的 Spring 版本中,这 3 个注释和 @Component 是等效的,但是从注释类的命名上,很容易看出这 3 个注释分别和持久层、业务层和控制层(Web 层)相对应。虽然目前这 3 个注释和 @Component 相比没有什么新意,但 Spring 将在以后的版本中为它们添加特殊的功能。所以,如果 Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用@Repository@Service  @Controller 对分层中的类进行注释,而用 @Component 对那些比较中立的类进行注释。 

在一个稍大的项目中,通常会有上百个组件,如果这些组件采用xmlbean定义来配置,显然会增加配置文件的体积,查找以及维护起来也不太方便。 Spring2.5为我们引入了组件自动扫描机制,他可以在类路径底下寻找标注了@Component,@Service,@Controller,@Repository注解的类,并把这些类纳入进spring容器中管理。它的作用和在xml文件中使用bean节点配置组件时一样的。要使用自动扫描机制,我们需要打开以下配置信息: 
Java
代码 

1.
  
2. >
 
3.  
 
4.   
 
5.   
 
6.
 其中base-package为需要扫描的包(含所有子包) @Service用于标注业务层组件,@Controller用于标注控制层组件(如struts中的action,@Repository用于标注数据访问组件,即DAO组件,而@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。   
7. @Service public class VentorServiceImpl implements iVentorService{  
 
8. } @Repository public class VentorDaoImpl implements iVentorDao {
 
9. } getBean
的默认名称是类名(头字母小写),如果想自定义,可以@Service(“aaaaa”)这样来指定,这种bean默认是单例的,如果想改变,可以使用@Service(“beanName”)@Scope(“prototype”)来改变。可以使用以下方式指定初始化方法和销毁方法(方法名任意): @PostConstructpublic void init() { 
10. }
 
11. @PreDestroy public void destory() {
 
12. }
 



注入方式: 

DAO实现类注入到service实现类中,把service的接口(注意不要是service的实现类)注入到action中,注 

入时不要new 这个注入的类,因为spring会自动注入,如果手动再new的话会出现错误,然后属性加上 

@Autowired
后不需要getter()setter()方法,Spring也会自动注入。至于更具体的内容,等对注入的方式更 

加熟练后会做个完整的例子上来。 

注解: 

 spring的配置文件里面只需要加上需要实现注入的类所在包"/>,可以使用base-package="*"表示全部的类。   

 

其中base-package为需要扫描的包(含所有子包) 

在接口前面标上@Autowired@Qualifier注释使得接口可以被容器注入,当接口存在两个实现类的时候必须指定其中一个来注入,使用实现类首字母小写的字符串来注入,如: 

    @Autowired     
 
  
 
    @Qualifier("chinese")      
 
  
 
     private Man man;   
 
否则可以省略,只写@Autowired   

@Service
服务层组件,用于标注业务层组件,表示定义一个bean,自动根据bean的类名实例化一个首写字母为小写的bean,例如Chinese实例化为chinese,如果需要自己改名字则:@Service("你自己改的bean")   

@Controller
用于标注控制层组件(struts中的action) 

@Repository
持久层组件,用于标注数据访问组件,即DAO组件 

@Component
泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。 


@Service
 
public class VentorServiceImpl implements iVentorService {
 
}
 

@Repository
 
public class VentorDaoImpl implements iVentorDao {
 
}
 

getBean
 的默认名称是类名(头字母小写),如果想自定义,可以@Service(“aaaaa”) 这样来指定,这种 

bean
默认是单例的,如果想改变,可以使用@Service(“beanName”)@Scope(“prototype”)来改变。 

可以使用以下方式指定初始化方法和销毁方法(方法名任意): 

@PostConstruct
 

public void init() {
 

}
 

@PreDestroy
 

public void destory() {
 

}
 

 

 

 

 

Spring@Autowired注解、@Resource注解的区别

BY ETHAN ON 2011 06  02  IN JAVA

Spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是@Resource@PostConstruct以及@PreDestroy
@Resource的作用相当于@Autowired,只不过@AutowiredbyType自动注入,而@Resource默认按 byName自动注入罢了。@Resource有两个属性是比较重要的,分是nametypeSpring@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
@Resource装配顺序
1. 如果同时指定了nametype,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常
4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

@Autowired @Resource的区别:

 

1 @Autowired@Resource都可以用来装配bean.都可以写在字段上,或写在setter方法上。

2 @Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,如:@Autowired(required=false),如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下:

1

@Autowired() @Qualifier("baseDao")

2

private BaseDao baseDao;

3@Resource(这个注解属于J2EE的),默认安装名称进行装配,名称可以通过name属性进行指定,如果没有指定name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。

1

@Resource(name="baseDao")

2

private BaseDao baseDao;

推荐使用:@Resource注解在字段上,这样就不用写setter方法了,并且这个注解是属于J2EE的,减少了与spring的耦合。这样代码看起就比较优雅

 

 

 

 

 

 

1.  使用Spring2.5Autowired实现注释型的IOC  

2.     

3.  本文地址:http://qzone.qq.com/blog/55357655-1232078233   

4.    

5.    使用Spring2.5的新特性——Autowired可以实现快速的自动注入,而无需在xml文档里面添加bean的声明,大大减少了xml文档的维护。(偶喜欢这个功能,因为偶对xml不感冒)。       以下是一个例子:  

6.  先编写接口Man  

7.         public interface Man  

8.             public String sayHello();  

9.   

10. 然后写Man的实现类ChineseAmerican  

11.        @Service  

12. public class Chinese implements Man{  

13.     public String sayHello()  

14.         return "I am Chinese!" 

15.      

16.  

17.   

18.        @Service  

19. public class American implements Man{  

20.     public String sayHello()  

21.         return "I am American!" 

22.      

23.  

24.   

25. @Service注释表示定义一个bean,自动根据bean的类名实例化一个首写字母为小写的bean,例如Chinese实例化为chineseAmerican实例化为american,如果需要自己改名字则:@Service("你自己改的bean")  

26.   

27. beans.xml  

0 0
原创粉丝点击