Spring相关基础(上)

本文介绍了Spring框架的基本概念,包括其作为企业级解决方案的角色、使用Spring的原因(解耦、AOP、测试支持等)、配置方式、单例Bean线程安全、组件扫描机制、自动装配原理以及IoC和DI的关系。还探讨了Spring Boot的扫描规则和如何实现依赖注入。

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

Spring相关基础

一、什么是Spring?

Spring是一个分层的JavaSE/EEfull-stack(一站式)轻量级开源框架。 Spring为不同的层都提供的企业级解决方案:
web层:spring mvc service层:spring dao层:mybatis
Spring的核心思想是IoC(控制反转)和AOP(面向切面编程)

二、为什么要使用Spring?

1.方便解耦,简化开发
Spring就是一个大工厂(容器),用于创建对象(bean)和维护对象间的依赖关系。
2.AOP编程的支持
Spring提供面向切面编程,可以方便的实现对程序进行权限拦截、运行监控等功能.
声明式事务的支持 ,只需要通过配置就可以完成对事务的管理,而无需手动编程
3.方便程序的测试
Spring对Junit4支持,可以通过注解方便的测试Spring程序
4.方便集成各种优秀框架
Spring支持各种优秀框架(如:SpringMVC、Mybatis、SpringBoot、SpringCloud等)
5.降低JavaEE API的使用难度
封装了一些API(JDBC、JavaMail等)降低开发

三、Spring Bean有哪些配置方式??

1.基于XML配置
在XML文件中通过元素定义Bean,如:
2.基于注解配置
在Bean实现类处通过标注@Component或衍型类(@Repository、@Service及@Controller)定义Bean
3.基于Java类配置
在标注了@Configuration的Java类中,通过在类方法上标注@Bean定义一个Bean。方法必须提供Bean的实例化逻辑

四、Spring框架中的单例Bean是线程安全的吗?

线程安全产生的原因是,多个线程对共享数据同时进行修改。
该问题分以下俩种情况:
1.有问题:如果类中存在成员变量(即共享数据),且成员变量中的数据在方法中会被修改,此时可能会产生线程安全问题;
2.没有问题:如果Bean没有成员变量,或者成员变量数据在访问的时候不会被修改,则不会产生线程安全问题。

五、Spring和SpringBoot中的扫描机制

1.Spring组件扫描:
在spring的配置类中使用@ComponentScan(basePackages = “com.czxy”)可以扫描com.czxy包以及子包下添加了指定注解的类。
常见的注解有: @Component、@Service、@Controller、@Repository

2.SpringBoot扫描机制
1)默认扫描规则,SpringBoot中会自动扫描启动类所在包及其子包中的所有添加了指定注解类
2)使用@ComponentScan注解可以覆盖默认扫描规则。

六、 Spring Bean的自动装配(自动注入)是怎么一回事?

自动装配,自动完成各个bean之间的依赖关系装配。
Spring提供了5种自动装配模式:
1.no:默认值,没有使用自动装配
2.byName 按照属性名自动装配。
3.byType 按照属性的数据类型自动装配。如果存在不止一个这样的bean,将抛出异常。
4.constructor 按照构造函数参数类型自动装配。(常见于xml配置)
5.default :默认值no

七、自动装配有哪些局限性?

  1. 不能自动装配基本数据类型、字符串、数组等

八、@Autowired和@Resource注解如何理解?

两个注解都可以完成依赖注入功能。
1.@Autowired:
@Autowired : 默认是以byType按类型自动注入。
@Autowired + @Qualifier(“名称”):将按照名称自动注入
2.@Resource:
@Resource() 如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称注入,
如果注解写在setter方法上默认取属性名进行注入。
当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名称进行装配。
@Resource(name=“”) 将按照名称自动注入

九、Spring不通过注入的方式怎么获取到对象?

1.通过ApplicationContext手动获取:手动加载xml或配置类获得上下文对象,通过getBean()获得指定名称的bean。

2.实现BeanFactoryAware接口:先获得BeanFactory,再getBean()获得指定名称的bean。
3.实现ApplicationContextAware 接口 :先获得ApplicationContext,再getBean()获得指定名称的bean。

参考:
https://www.aliyun.com/jiaocheng/812869.html

十、什么是控制反转(IoC)?

IoC:Inversion of Control,即“控制反转”,不是什么技术,而是一种设计思想。Ioc意味着将你设计好的对象交给容器控制,而不是new。
IoC 控制反转,指将对象的创建权,反转到Spring容器

十一、什么是Spring IoC容器?

IOC容器就是一个Map集合,里面存放实例化的对象

十二、IoC有哪些优点?

1.减少代码的耦合,可以使应用更加模块化
2.增加代码的复用率
3.资源更加统一管理
4.维护代码更加方便,一般只需要修改一下配置文件就ok了。
5.提升了程序的测试性
链接:https://www.imooc.com/article/35099

十三、什么是依赖注入(DI)?

DI:Dependency Injection 依赖注入,在Spring框架创建Bean对象时,动态的将依赖对象注入到Bean组件

十四、DI是怎么实现的?

    ①setter注入:
    ②构造器注入:
    ③注解注入

十五、IoC和DI的关系

IoC 控制反转,指将对象的创建权,反转到Spring容器 , DI
依赖注入,指Spring创建对象的过程中,将对象依赖属性通过配置进行注入 DI依赖注入不能单独存在,必须在IoC控制反转的基础上才能完成。

十六、怎么用Spring框架下实现IoC?

IoC控制反转:指将对象的创建权,反转到Spring容器 方式1:创建工厂
创建一## 标题个工厂,用于创建目标对象,就是最简单的IoC。但工厂和目标类耦合。 方式2:工厂 + 配置文件
1)配置文件中存放类的全限定名称
2)编写工厂,用于读取配置文件中的内容,并通过反射创建对象。
问题:工厂只能生产一个对象 方式3:工厂 + properties文件
1)properties配置文件存放一组,key是标识,value是全限定名称
2)编写工厂类,读取配置文件
3)提供getBean( name ) 用于生成实例:通过name获得对应的全限定名称,再通过反射创建对应的实例。

十七、Spring的拦截如何实现?

使用AOP,使用前置通知、后置通知、环绕通知等等去实现拦截

AOP相关基础点见下篇。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值