小记【spring】bean的配置

bean配置的方式

  • 通过xml
    这种方式较为繁琐,但是自定义的东西较多,id,ref都可自行定义;无需按照spring相关默认的方式进行注册
    (在使用 XML 配置 Bean 时,ref 元素通常是用来引用其他已经定义的 Bean,并且是通过 Bean 的 id 来进行引用和注入的。这种方法使得在 XML 配置的 Spring 应用程序中可以灵活地管理和注入依赖)

  • 注解方式
    如 常见的 @Resource @Autowired 等等 – 为什么他们能直接通过注解即可声明一个bean呢? 主要是因为(下面会说他们之间的区别)@Resource 是依赖 CommonAnnotationBeanPostProcessor 里面有对javax.annotation.Resource 注解的扫描
    至于 service、component controller 的话则是依赖于 componentScan,依次遍历扫描到之后,将其注册成bean

  • java 配置方式(依赖于 configuration 和 bean 注解)

较为推崇的则有:
  • 注解自动装配
    创建对象以及处理对象依赖关系,相关的注解:
    @ComponentScan扫描器
    @Configuration表明该类是配置类
    @Component 指定把一个对象加入IOC容器
    @Repository 作用同@Component; 在持久层使用
    @Service 作用同@Component; 在业务逻辑层使用
    @Controller 作用同@Component; 在控制层使用
    @Resource 依赖关系
    如果@Resource不指定值,那么就根据类型来找,相同的类型在IOC容器中不能有两个相同类型的bean,这里所说的类型【应该是同名、同类路径吧?】如果@Resource指定了值,那么就根据名字来找
@Resource和@Autowire

@Resource注解也可以完成属性注入。那它和@Autowired注解有什么区别?

  • @Resource注解是JDK扩展包中的,也就是说属于JDK的一部分。所以该注解是标准注解,更加具有通用性。(USR-250标准中制定的注解类型。JSR是Java规范提案。)
  • @Autowired注解是Spring框架自己的。
  • @Resource注解默认根据名称装配byName,未指定name时,使用属性名作为name。通过name找不到的话会自动启动通过类型byType装配。
  • @Autowired注解默认根据类型装配byType,如果想根据名称装配,需要配合@Qualifier注解一起用。
  • @Resource注解用在属性上、setter方法上。
  • @Autowired注解用在属性上、setter方法上、构造方法上、构造方法参数上。
  • @Resource注解属于JDK扩展包,所以不在JDK当中,需要额外引入以下依赖:【如果是JDK8的话不需要额外引入依赖。高于JDK11或低于JDK8需要引入以下依赖
<dependency>
  <groupId>jakarta.annotation</groupId>
  <artifactId>jakarta.annotation-api</artifactId>
  <version>xxx</version>
</dependency>

在这里插入图片描述

补充:

  • @Bean 方法中的参数
    Spring 框架在处理 @Bean 方法中的参数时,默认的行为与 @Autowired 注解的工作方式是一致的
  • 通用的xml文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd" 
       可以加上 这个 default-autowire="byName" >


    <bean id="appinfo" class="APPInfoDO" >
        <property name="appName" value="ABC"/>
    </bean>

    <bean id="aService" class="AService" >
    </bean>

    <!--日常为1.0.0.daily 预发和线上是1.0.0-->
    <bean id="aService" class="AService" init-method="init">
     
    <bean id="aClient" class="AClient" init-method="init">
        <property name="info" ref="appinfo" />
        <property name="aService" ref="aService" />
    </bean>
</beans>

  • 20
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Protobuf是一种高效的序列化协议,可以用于数据交换和数据存储。它的主要优势是大小小,速度快,可扩展性强。下面是使用Protobuf的一些小记: 1. 定义消息格式 首先,需要定义消息格式,以便Protobuf可以将数据序列化和反序列化。消息格式定义在.proto文件中,使用protobuf语言编写。例如,下面是一个简单的消息格式定义: ``` syntax = "proto3"; message Person { string name = 1; int32 age = 2; } ``` 这个消息格式定义了一个名为Person的消息,包含两个字段:name和age。 2. 生成代码 一旦消息格式定义好,就可以使用Protobuf编译器生成代码。编译器将根据消息格式定义生成相应的代码,包括消息类、序列化和反序列化方法等。可以使用以下命令生成代码: ``` protoc --java_out=. message.proto ``` 这将生成一个名为message.pb.javaJava类,该类包含Person消息的定义以及相关方法。 3. 序列化和反序列化 一旦生成了代码,就可以使用Protobuf序列化和反序列化数据。例如,下面是一个示例代码,将一个Person对象序列化为字节数组,并将其反序列化为另一个Person对象: ``` Person person = Person.newBuilder() .setName("Alice") .setAge(25) .build(); byte[] bytes = person.toByteArray(); Person deserializedPerson = Person.parseFrom(bytes); ``` 这个示例代码创建了一个Person对象,将其序列化为字节数组,然后将其反序列化为另一个Person对象。在这个过程中,Protobuf使用生成的代码执行序列化和反序列化操作。 以上是使用Protobuf的一些基本步骤和注意事项,希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值