Spring框架中问题补充

BeanFactory 和 ApplicationContext

BeanFactory和ApplicationContext是接口。BeanFactory接口时spring框架的顶层接口,定义管理bean的最基本的方法,例如获取实例、判断等功能。

DefaultListableBeanFactory实现BeanFactory 接口,是主要的创建bean的工厂类.

ApplicationContext也间接继承了BeanFactory,并拓展一些新的功能,之间的关系像心脏和身躯、都可以当作Spring的容器。

区别:

BeanFactory面向spring框架的基础设施,比较底层 ;
ApplicationContext由于又实现许多的接口,增加了额外的功能。

实现了BeanFactory接口的工厂,是懒加载,获取bean时才会创建对象;
实现了ApplicationContext接口的工厂,是在启动时加载所有的类,创建对象。

SpringBean 的生命周期

spring中的所说的bean对象是指spring框架创建管理的我们的对象

生命周期

1.实例化 Instantiation:通过反射机制以及工厂创建出来的原始对象
2.属性赋值 Populate 
3.初始化 Initialization:
完成对原始对象的各种功能增强AOP生成代理对象,再放到容器中使用。
4.销毁 Destruction

Spring 中的 bean 是线程安全的吗?

spring中的bean是否线程安全需要看bean的作用域。
scope="singleton" 单例:线程不安全, 使用TheadLocal为每个请求创建一个变量副本。
scope="prototype" 原型:线程安全, 一个请求到来,创建一个对象.

线程安全要从单例bean与原型bean分别说明。
原型bean:每次创建一个新对象,线程安全。
单例bean:所有线程共享实例bean,存在资源竞争。bean又分为有状态bean(用来存储数据的)和无状态bean(没有存储数据 Service,Dao 层只是方法调用)。如果单例bean是无状态的,那么线程安全。如果单例bean是有状态的,本身是线程不安全,需要自己进行线程安全的保证。

Bean 循环依赖

两个类之间相互关联(依赖),A类中关联B类,B类中关联A类。这个在自己new 对象时,没有问题,会直接给关联的对象赋值为null。但是在spring中会出现问题,在spring管理的bean时,在自定注入时,如果两个类相互之间关联,那么会出现注入时,另一个对象还没有初始化完成的情况。

spring中解决循环依赖问题:

通过三级缓存(就是三个Map对象)
一级缓存(singletonObjects): 主要存储初始化完成的对象。
二级缓存(earlySingletonObjects): 存储实例化完成的半成品bean对象, 提前暴露给需要的地方。
三级缓存(singletonFactories): 放的是创建对象的工厂。

当A中需要B时, 会先从一级缓存中找B,没有,然后到二级缓存中找B,也没有,就去三级缓存中,找到B对应的工厂,创建出B对象(原始对象,半成品),把B对象放到了二级缓存中。

 Servlet 的过滤器与 Spring 拦截器区别

过滤器Filter属于javaweb(serlet规范)中定义的,实现控制由服务器调度,拦截范围更大,所有进入到web后端的请求,都可以被过滤器拦截。
拦截器Interceptor实在请求进入servlet后,在进入Controller之前进行预处理的。

 Spring 常用注解

声明 bean 的注解

@Component:泛指各种组件
@Controller、@Service、@Repository 都可以称为@Component
@Controller:控制层
@Service:业务层
@Repository:数据访问层

Bean 的生命周期属性

@Scope 设置类型包括:设置 Spring 容器如何新建 Bean 实例
singleton:单例,一个 Spring 容器中只有一个 bean 实例,默认模式
protetype:每次调用新建一个 bean
request:web 项目中,给每个 http request 新建一个 bean
session:web 项目中,给每个 http session 新建一个 bean
globalSession:给每一个global http session 新建一个 Bean 实例

注入 bean 的注解

@Autowired:由 Spring 提供,用来给指定的字段或方法注入所需的外部资源。
@Qualifier: 当有多个同一类型的 Bean 时,可以用@Qualifier(“name”)来指定。与 @Autowired 配合使用.
@Resource:由 java 提供,只根据type进行注入,不会去匹配name。

切面(AOP)相关注解

Spring 支持 AspectJ 的注解式切面编程
@Aspect:声明一个切面
@After:在方法执行之后执行(方法上)
@Before:在方法执行之前执行(方法上)
@Around:在方法执行之前与之后执行(方法上)
@PointCut:声明切点
@EnableAspectJAutoProxy:开启 Spring 对 AspectJ 代理的支持

SpringMVC 常用注解

@RestController : 该 注 解 为 一 个 组 合 注 解 , 相 当 于 @Controller 和 @ResponseBody 的组合,注解在类上,意味着,该 Controller 的所有方法都 默认加上了@ResponseBody。 @RequestMapping:用于映射 web 请求,包括访问路径和参数
@ResponseBody:支持将返回值放到 response 内,而不是一个页面,通常用 户返回 json 数据 @RequestBody:允许 request 的参数在 request 体中,而不是在直接连接的 地址后面

其他注解

@JsonFormat:此注解用于属性或者方法上(最好是属性上),可以方便的把 Date 类型直接转 化为我们想要的模式.
@Transactional:注解放在类级别时,表示所有该类的公共方法都配置相同的事务属性信息。

SpringBoot 注解

@SpringBootApplication: 包含@Configuration、@EnableAutoConfiguration、@ComponentScan 通常用在主类上;
@RestControllerAdvice,@ExceptionHandler 用于统一异常处理,捕获指定的异常.

配置类相关注解

@Configuration:声明当前类为配置类
@Bean:注解在方法上,声明当前方法的返回值为一个 bean,替代 xml 中的方式 @ComponentScan:用于对 Component 类型注解进行扫描

SpringBoot 自动装配原理

在启动类上有个注解 :@SpringBootApplication

@SpringBootApplication  //组合注解



@SpringBootConfiguration
@EnableAutoConfiguration  //开启自动配置
@ComponentScan(
    excludeFilters = { @Filter(
    type = FilterType.CUSTOM, 
    classes = {TypeExcludeFilter.class}
), @Filter(
    type = FilterType.CUSTOM, 
    classes = {AutoConfigurationExcludeFilter.class}
)}//扫描启动类所在包下所有加注解的类
            
            
@EnableAutoConfiguration       
    @Import(AutoConfigurationImportSelector.class)
        this.getAutoConfigurationEntry
            this.getCandidateConfigurations

      1.AutoConfigurationImportSelector导入并选择需要加载组件。
      2.读取 meta-info/spring.factories 文件中所有组件的自动配置类。
      3.只需加载我们在pom.xml中配置的组件配置类,把meta-info/spring.factories多余的组件剔除。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值