首页>>后端>>Spring->@bean?

@bean?

时间:2023-12-02 本站 点击:0

spring 的方法上加 @Bean 的作用

1.@Bean明确地指示了一种方法,

2.什么方法呢——产生一个bean的方法,并且交给Spring容器管理;

3.很明确地告诉被注释的方法,你给我产生一个Bean,然后交给Spring容器

4.@Bean明确地指示了一种方法,什么方法呢——产生一个bean的方法,并且交给Spring容器管理

注:@Bean就放在方法上,就是产生一个Bean

@Bean在@Configuration和在@Component中的区别

Spring 注解@Component,@Service,@Controller,@Repository

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

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

Java代码

1. ?xml version="1.0" encoding="UTF-8" ? beans xmlns="" xmlns:xsi="" xmlns:context="" xsi:schemaLocation=" "

2.

3.

4. context:component-scan base-package=”com.eric.spring”

5. /beans

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

@Service用于标注业务层组件,

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

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

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

*/

6. @Service public class VentorServiceImpl implements iVentorService {

7. } @Repository public class VentorDaoImpl implements iVentorDao {

8. }

/*getBean的默认名称是类名(头字母小 写),如果想自定义,可以@Service(“aaaaa”)这样来指定,这种bean默认是单例的,如果想改变,可以使用 @Service(“beanName”) @Scope(“prototype”)来改变。可以使用以下方式指定初始化方法和销毁方法(方法名任意): @PostConstruct public void init() {

*/

9. }

10. @PreDestroy public void destory() {

11. }

注入方式:

把 DAO实现类注入到service实现类中,把service的接口(注意不要是service的实现类)注入到action中,注入时不要new 这个注入的类,因为spring会自动注入,如果手动再new的话会出现错误,然后属性加上@Autowired后不需要getter()和 setter()方法,Spring也会自动注入。至于更具体的内容,等对注入的方式更加熟练后会做个完整的例子上来。

注解:

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

context:component-scan base-package=”com.eric.spring”

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

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

@Autowired

@Qualifier("chinese")

private Man man;

使用Autowired注入的步骤:

1.首先根据类型找到所有可以满足条件的bean

2.判断bean长度,如果没有,则根据@autowired中的required属性进行判断是否抛出异常(默认为true)

3.如果多于一个,则尝试寻找最优的那一个,如果最优的未找到,则抛出异常

4.如果只有一个,则直接使用此bean

否则可以省略,只写@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() {

}

如果xml文件中配置了业务层的bean,则在业务实现层类上无需添加@Service注解。同样如果配置了持久层的bean也就无需在dao实现层类上添加@Repository

注解bean的用途

1、@Component注解表明一个类会作为组件类,并告知Spring要为这个类创建bean。

2、@Bean注解告诉Spring这个方法将会返回一个对象,这个对象要注册为Spring应用上下文中的bean。通常方法体中包含了最终产生bean实例的逻辑。

两者的目的是一样的,都是注册bean到Spring容器中。

区别:

@Component(@Controller、@Service、@Repository)通常是通过类路径扫描来自动侦测以及自动装配到Spring容器中。

而@Bean注解通常是我们在标有该注解的方法中定义产生这个bean的逻辑。

@Component 作用于类,@Bean作用于方法。

总结:

@Component和@Bean都是用来注册Bean并装配到Spring容器中,但是Bean比Component的自定义性更强。可以实现一些Component实现不了的自定义加载类。

Spring中@Bean和FactoryBean作用和区别

FactoryBean并不是简单的@Bean 

一般情况下,Spring通过反射机制利用的class属性指定实现类实例化Bean,在某些情况下,实例化Bean过程比较复杂,如果按照传统的方式,则需要在中提供大量的配置信息。配置方式的灵活性是受限的,这时采用编码的方式可能会得到一个简单的方案。Spring为此提供了一个org.springframework.bean.factory.FactoryBean的工厂类接口,用户可以通过实现该接口定制实例化Bean的逻辑。FactoryBean接口对于Spring框架来说占用重要的地位,Spring自身就提供了70多个FactoryBean的实现。它们隐藏了实例化一些复杂Bean的细节,给上层应用带来了便利。从Spring3.0开始,FactoryBean开始支持泛型,即接口声明改为FactoryBeanT的形式

FactoryBean底层Java8实现两个方法:

@Override public Object getObject() throwsException {

     logger.debug("getObject......");

     returnproxyObj; }

 @Override public ClassgetObjectType() {

         return proxyObj == null ? Object.class : proxyObj.getClass();

    }

FactoryBean是个接口,可以实例化两个对象,当在IOC容器中的Bean实现了FactoryBean后,通过getBean(String BeanName)获取到的Bean对象并不是FactoryBean的实现类对象,而是这个实现类中的getObject()方法返回的对象。要想获取FactoryBean的实现类,就要getBean(BeanName),在BeanName之前加上。

spring boot@bean是什么意思?

相信使用过springboot 的人都有用过@Configuration加上@Bean去注册一个bean 对象,这样我们就不用再去写xml文件去注册bean对象。

而@Configuration标注在类上,相当于把该类作为spring的xml配置文件中的 beans,作用为:配置spring容器(应用上下文),

@Bean标注在方法上(返回某个实例的方法),等价于spring的xml配置文件中的 bean,作用为:注册bean对象。

那使用xml注册bean对象和使用注解@Bean注册对象之间有什么明显的区别呢?比较明显的区别在于加载对象存在一定的先后顺序时会出现一个循环加载Bean的问题,容易出现在于使用动态数据源切换,继承AbstractRoutingDataSource实现的方法。为什么会出现这样的一种情况,这个就归结于springboot加载@Bean不是按照写代码的顺序加载的,解决的办法也是有的使用@Order注解的或者@Bean的方法上标识@DependsOn注解,来指定当前Bean实例化时需要触发哪些Bean的提前实例化。所以我还是建议在容易出现循环加载的地方使用xml配置文件初始化bean,然后在Application.class中添加上@ImportResource导入相应的xml文件。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:/Spring/9983.html