Spring框架基础知识

Spring框架基础知识笔记

Spring中bean的生命周期 ,指Bean从创建、初始化、使用到销毁的整个过程。
Bean实例化->依赖注入->Aware接口的回调->BeanPostProcessor前置处理->初始化方法->BeanPostProcessor后置处理->Bean使用->Bean销毁

循环引用(Circular Dependency)是指两个或多个Bean互相依赖,导致无法完成依赖注入的情况。BeanA的构造器依赖BeanB,而BeanB的构造器依赖BeanA;或者是BeanA有一个属性依赖于BeanB,而BeanB也有一个属性依赖于BeanA。这种循环依赖通过Spring的一级、二级、三级缓存机制是可以解决的。

java 复制代码
@Component
public class BeanA {
    @Autowired
    private BeanB beanB;

    public BeanA() {
    }

    public void setBeanB(BeanB beanB) {
        this.beanB = beanB;
    }
}

@Component
public class BeanB {
    @Autowired
    private BeanA beanA;

    public BeanB() {
    }

    public void setBeanA(BeanA beanA) {
        this.beanA = beanA;
    }
}
java 复制代码
@Component
public class BeanA {
    @Autowired
    @Lazy
    private BeanB beanB;
}

在spring框架中,使用注解singleton,一般是Scope注解代表bean可以在IOC容器中作为单例,使用prototype则一个bean可以定义多个实例。

而bean并不属于线程安全的范畴。有状态的都不安全(可修改)。

AOP 是面向切面编程,也就是可以重用的模块,多次重复使用的方法进行封装,降低耦合问题。@Around("pointcut()")。(如日志记录)。

事务@Transaction)是为了确保一组操作在数据库中是原子性的(是一个不可分割的整体,所有操作要么都执行,要么都不执行),要么所有操作成功并提交,要么任何一个操作失败时,全部回滚,保持数据一致性。分为声明式事务管理编程式事务管理。事务失效的情况,一般就是抛出异常出问题。

java 复制代码
@Service
public class MyService {
    @Transactional
    public void someTransactionalMethod() {
        // 数据库操作
    }
}
java 复制代码
// propagation 传播行为(REQUIRED当前方法必须在事务中运行),isolation 事务之间的隔离程度,timeout 事务执行最长时间,readOnly 只读
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.READ_COMMITTED, timeout = 30, readOnly = false)
public void updateData() {
    // 更新数据库的操作
}

MVC框架M odel处理数据和业务逻辑,V iew负责展示数据和用户界面,Controller协调模型和视图,处理请求和返回响应。

相关推荐
盐真卿2 小时前
python第八部分:高级特性(二)
java·开发语言
布列瑟农的星空2 小时前
前端都能看懂的Rust入门教程(三)——控制流语句
前端·后端·rust
上海合宙LuatOS2 小时前
LuatOS核心库API——【audio 】
java·网络·单片机·嵌入式硬件·物联网·音视频·硬件工程
汤姆yu2 小时前
基于springboot的尿毒症健康管理系统
java·spring boot·后端
TT哇2 小时前
【实习】银行经理端线下领取扫码功能实现方案
java
暮色妖娆丶3 小时前
Spring 源码分析 单例 Bean 的创建过程
spring boot·后端·spring
野犬寒鸦3 小时前
从零起步学习JVM || 第一章:类加载器与双亲委派机制模型详解
java·jvm·数据库·后端·学习
黎雁·泠崖3 小时前
【魔法森林冒险】2/14 抽象层设计:Figure/Person类(所有角色的基石)
java·开发语言
Java编程爱好者3 小时前
Seata实现分布式事务:大白话全剖析(核心讲透AT模式)
后端
神奇小汤圆3 小时前
比MySQL快800倍的数据库:ClickHouse的性能秘密
后端