首页 > 基础资料 博客日记

Spring5学习随笔-基础注解编程

2023-11-22 12:13:10基础资料围观251

本篇文章分享Spring5学习随笔-基础注解编程,对你有帮助的话记得收藏一下,看Java资料网收获更多编程知识

学习视频:【孙哥说Spring5:从设计模式到基本应用到应用级底层分析,一次深入浅出的Spring全探索。学不会Spring?只因你未遇见孙哥】

注解编程-第一章、注解基础概念

1.什么是注解编程

指的是在类或方法上加入特定的注解(@XXX),完成特定功能的开发.

2.为什么要讲解注解编程

  1. 注解开发方便

    代码简介 开发速度大大提高

  2. Spring开发潮流

    Spring2.x引入注解 Spring3.x完善注解 SpringBoot普及 推广注解编程

3.注解的作用

  • 替换XML这种配置形式,简化配置

    @Component 代替/等效配置中的bean对象

  • 替换接口,实现调用双方的契约性

通过注解的方式,在调用者和功能提供者之间达成约定,进而进行功能的调用,因为注解应用更为方便灵活,所以在现在的开发中,更推荐通过注解的形式完成

4.Spring注解的发展历程

  1. Spring2.x开始支持注解编程 @Component @Service @Scope

    目的:提供这些注解只是为了在某些情况简化XML的配置,作为XML开发的有益补充

  2. Spring3.x @Configuration @Bean

    目的:彻底替换XML,基于纯注解编程

  3. Spring4.x SpringBoot

    提倡使用注解常见开发

5.Spring注解开发的一个问题

Spring基于注解进行配置后,还能否解耦合呢?

在Spring框架应用注解时,如果对注解配置的内容不满意,可以通过Spring配置文件进行覆盖。

第二章、Spring的基础注解(Spring2.x)

这个阶段的注解,仅仅是简化XML的配置,并不能完全代替XML

1.对象创建相关注解

  • 搭建开发环境
<context:component-scan base-package="com.baizhi"/>
作用:让Spring框架在设置的包下扫描对应的注解,使其生效
  • 对象创建相关注解

    • @Component

    作用:替换原有Spring配置文件中的bean标签

    注意:id属性 cmponent注解 提供了默认的设置方式 首单词首字母小写

    class属性 通过反射获得class内容

    @Component 代替/等效配置中的bean对象

    • @Component细节

      如何显示指定工厂创建对象的id值

      @Component("u”) 参数可以设置id值

      • Spring配置文件覆盖注解配置内容

        applicationContext.xml
        <bean id="u" class="com.baizhi.bean.User"/>
        
    • @Component的衍生注解

      @Repository 应用在DAO类型
      @Service    应用在Service类
      @Controller 应用在Controller类
      **注意:本质上这些衍生注解就是@Component 作用、细节、用法都是完全一致
      目的:更加准确的表达一个类型的作用
      注意:Spring整合Mybatis开发过程中 不使用@Repository @Component**
      
  • @Scope注解

    作用:控制简单对象创建次数 等同于scope属性

    注意:不添加@Scope,Spring还是会提供默认值singleton

    <bean id="" class="" scope="singleton|prototype"/>
    
  • @Lazy注解

    作用:延迟创建单实例对象

    注意:一旦使用了@Lazy注解后,Spring会在使用这个对象的时候,才进行对象的创建

    <bean id="" class="" lazy="false"/>
    
  • 生命周期方法相关注解

    1. 初始化相关方法 @PostConstruct

    2. 销毁方法 @PreDestroy

    注意:1.上述的2个注解并不是Spring提供的,是JSR(JavaEE规范)520提供的

    **2.再一次的验证,通过注解实现了接口的契约性**
    

2.注入相关注解

  • 用户自定义类型注入 @Autowired

    @AutoWired细节

    1. Autowired注解基于类型进行注入[推荐]

      基于类型的注入:注入对象的类型,必须与目标成员变量类型相同或者是其子类(实现类)

    2. Autowired加上Qualifier 可以基于名字进行注入[了解即可]

      注入对象id值,必须与Qualifier注解中设置的名字相同

    3. Autowired注解放置位置

      1. 放置在对应成员变量的set方法上
      2. 直接把这个注解放置在成员变量之上,Spring通过反射直接对成员变量进行注入(赋值)[推荐]
    4. JavaEE规范中提供类似功能的注解

      JSR250 @Resouce(name=”userDAOImpl”) 基于名字进行注入

      注意:应用Resource注解时,名字没有配置成功,那么他会继续按照类型进行注入

      JSR330 @Inject 作用 @Autowired完全一致 基于类型进入注入 —→EJB3.0

  • JDK类型

    @Value注解完成

    1. 设置xxx.properties

      id = 10

      name = suns

    2. Spring的工厂读取这个配置文件

      <context:property-placeholder location=””/>

    3. 代码

      属性 @Value("${key}”)

    • @PropertySource
      1. 作用:用于替换Spring配置文件中的<context:property-placeholder location=””/>标签
      2. 开发步骤
        1. 设置xxx.properties

          id=10

          name=suns

        2. 应用@PropertySource

        3. 代码

          属性@Value()

@Component
@PropertySource("classpath:/init.properties")
public class Category {
    @Value("${id}")
    private Integer id;
    @Value("${name}")
    private String name;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}
  • @Value注解细节
    • @Value注解不能给静态成员变量赋值
    • @Value注解+Properties这种方式,不能注入集合类型
      • Spring提供新的配置形式 YAML YML(SpringBoot)

3.注解扫描详解

<context:component-scan base-package="com.baizhi"/>
当前包 及其 子包

1.排除方式

<context:component-scan base-package="com.baizhi">
		<context:exclude-filter **type**="" expression=""/>
		**type参数讲解**:assignable:排除特定的类型 不进行扫描
									annotation:排除特定的注解  不进行扫描
									aspectj:切入点表达式 
														包切入点:com.baizhi.bean..*
														类切入点:*.User
									regex:正则表达式来进行排除
									custom:自定义排除策略
</context:component>

排除策略可以叠加使用
<context:component-scan base-package="com.baizhi">
        <context:exclude-filter type="assignable" expression="com.baizhi.bean.User"/>
        <context:exclude-filter type="aspectj" expression="com.baizhi.injection..*"/>
</context:component-scan>

实际开发中常用assignable、annotation、 aspectj(用的最多,切入点表达式)更方便

2.包含方式

和排除方式是相反的,它决定了哪些类的注解被Spring扫描

<context:component-scan base-package="com.baizhi" use-default-filters="false">
      <context:include-filter type="" expression=""/>
</context:component-scan>

1. use-default-filters="false"
	作用:让Spring默认的注解扫描方式 失效
2. <context:include-filter type="" expression=""/>
	作用:指定扫描那些注解
	type:assignable:指定特定的类型 不进行扫描
				annotation:指定特定的注解  不进行扫描
				aspectj:切入点表达式 
									包切入点:com.baizhi.bean..*
									类切入点:*.User
				regex:正则表达式来进行排除
				custom:

包含的方式支持叠加
<context:component-scan base-package="com.baizhi" use-default-filters="false">
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Repository"/>
        <context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
    </context:component-scan>

4.对于注解开发的思考

  • 配置互通

    Spring注解配置 配置文件的配置 互通

    @Repository
    public class UserDAOImpl{
    
    }
    
    public class UserServiceImpl{
    		private UserDAO userDAO;
    		set get..
    }
    
    <bean id="userService class="com.baizhi.UserServiceImpl">
    		<property name="userDAO" ref=""/>ref会提示userDAO的选项
    </bean>
    
  • 什么情况下使用注解 什么情况下使用配置文件

    @Component 替换 <bean

    基础注解(@Component @Autowired @Value) 程序员开发类型的配置

    1. 在程序员开发的类型上 可以加入对应注解 进行对象的创建

      User UserService UserDAO UserAction

    2. 应用其他非程序员开发的类型时,还是需要<bean 进行配置的

      SqlSessionFactoryBean MapperScannerConfigure


文章来源:https://www.cnblogs.com/eyewink/p/17848718.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!

标签:

相关文章

本站推荐

标签云