各类注解以及通过注解的方式实现Spring的IOC和DI

本文深入讲解Spring框架中注解的应用,包括注解的基本概念、自定义注解开发、反射注解原理,以及如何使用注解实现Spring的依赖注入(DI)和控制反转(IoC)。介绍了@Component、@Service、@Controller、@Repository等常用注解,以及@Autowired、@Qualifier在DI中的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第二天复习的内容便是各类注解以及通过注解的方式实现Spring的IOC和DI

注解回顾
  • 注解的概念
    注解是给人看的信息,人看了提示信息了解程序的内容

  • jdk内置注解

    • @Override 声明重写父类方法的注解
    • @Deprecated 声明方法使用过时,不建议使用
    • @SuppressWarnings 压制警告,提示编译器在编译的过程中对指定类型的警告不再提示
  • 自定义注解开发

    • 开发一个注解类:
      开发一个注解类的过程类似鱼开发一个接口,只不过需要通过@interface关键字来声明
    • 使用元注解修饰注解的声明
      所谓的元注解是用来修饰注解声明的注解,可以控制被修饰的注解的特性。
      • @Target
        用来声明被修饰的注解可以用子什么位置
      • @Retention
        用来声明修饰的注解会被保留到什么阶段,属性有:
        • RetentionPolicy.CLASS
          这种注解会保留到源码阶段,.java中,在编译的过程中被删除
        • RetentionPolicy.CLASS
          此注解将会保留在源码阶段和编译阶段, .java和.class中,在类加载的过程中被删除
        • RetentiongPolicy.RUNTIME
          此注解会保留在源码阶段、编译阶段和运行阶段,.java .class 字节码中都会存在
      • @Documented
        用来声明被修饰的注解是否要被文档提取工具提取到文档中
      • @Inherited
        被修饰的注解是否具有继承性
    • 为注解增加属性
      注解类中还可以声明属性。
      为注解类声明属性的过程类似于为接口定义方法
  • 反射注解

    • 反射注解原理
      RetentionPolicy.RUNTIME级别的注解会保留到运行期,可以通过反射技术获取,从而可以根据是否有注解或注解属性值的不同控制程序按照不同方式运行
isAnnotationPresent如果指定类型的注释存在于此元素上,返回true,否则false
getAnnotation如果存在该元素的指定类型的注释,则返回这些注释,否则返回null
getAnnotations返回此元素上存在的所有注释
Spring注解
概念

spring除了默认的使用xml配置文件的方式实现配置之外,也支持使用注解方式实现配置,这种方式效率更高,配置跟清晰

引入context命名空间

xmlns:context=“http://www.springframework.org/schema/context

使用注解的方式实现IOC
  • 开启包扫描
 <context:component-scan base-package="com.zhe.*"/>
  • 使用注解注册bean
    在配置包的类上使用@Component注解,这个类会被自动注册为bean,使用当前类的class为bean的class
@Component("s")
public class ProductService {
    public void doSomeService(){
        System.out.println("ProductService");
    }
}
  • bean的id
    通常情况下注解注册bean使用类名首字母小写为bean的id,但是如果类名的第二个字母为大写则首字母保留原样
    通过@Component中配置value属性,明确指定bean的id
Spring 注解方式实现DI
  • 配置文件中开启使用DI
    <!--开启注解配置DI-->
    <context:annotation-config></context:annotation-config>
  • 注解方式注入spring内置支持的类型数据-非集合类型
    方式:@Value
    但是,这种方式将注入的值写死在了代码中,后续如果要修改就要修改源代码,所以我们可以使用外部文件的方式,即使用properties配置文件,后续再导入

  • 注解方式注入spring内置支持的类型数据-集合类型

    • spring-util包
    • 注册util标签数据
    • 使用:@Value("#{@id}")
使用注解注入自定义的bean数据类型

在bean中的属性上通过@Autowired实现自定义bean类型属性注入代码
当Spring容器解析到@Component注解时,创建当前类的bean在spring容器中进行管理,在创建bean的过程中发现了@Autowired注解,会根据当前bean属性名称,寻找在spring中是否存在id等于该名称的bean,如果存在就自动注入。如果不存在,再检查是否存在和当前bean属性类型相同的bean,如果存在就注入进来,如果不存在则抛出异常。

自动配置:

​ 组件装配< context:component-scan>元素还会自动注册AutowireAnnotationBeanPostProcessor实例,该实例可以自动装配具有**@Autowired**和@Resource、@Inject注解属性。

​ @Autowired使用的次数最多

​ @Autowired注解自动装配具有兼容类型的单个Bean属性

  • 构造器,普通字段(即使是非public),具有参数的方法都可以应用@Autowired注解
  • 默认情况下,所有使用@Autowired注解的属性都需要被设置,当spring找不到匹配的bean装配属性时,会抛出异常,若某一属性不允许不被设置,可以设置@Autowired注解的required属性为false
@Autowired(required = false) 这种方式可以在注解类没有配置好的时候渐少对于异常的问题
  • 默认情况下,当IOC容器里存在多个类型兼容的bean时,通过类型的主动装配将无法工作,此时可以在@Qualifiter已指定注入Bean的名称

如果没有指定bean,会优先寻找同名的类,@Qualifier(“userJdbcReposidtory”)可以选择指定的bean

  • @Autowired注解也可以应用在数组类型的属性上,此时spring将会把所有匹配的bean进行自动装配
  • @Authwired注解也可以应用在集合属性上,此时spring读取集合的类型信息,然后自动装配与之兼容的bean
  • @Autowired注解用在java.util.Map上时,若该Map的键值为string,那么spring将自动装配与之Map值类型兼容的bean,此时bean的名称作为键值
        <!--自动装配-->
        <!-- 配置自动扫描的包 -->
        <context:component-scan base-package="com.zhe.spring.jdbc">
		</context:component-scan>
其它注解
  • @Controller
    web层注解
  • @Service
    service层注解
  • @Repository
    dao层注解
  • @Component
    通用的注解

功能是一样的,作用是为了控制代码的规范

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值