10.3学习

news/2024/10/5 19:41:21/

1.循环依赖

循环依赖其实就是循环引用,也就是两个或者两个以上的 Bean 互相持有对方,最终形成闭环。比如A 依赖于B,B又依赖于A

 

Spring中循环依赖场景有:

prototype 原型 bean循环依赖

构造器的循环依赖(构造器注入)

Field 属性的循环依赖(set注入)

其中,构造器的循环依赖问题无法解决,在解决属性循环依赖时,可以使用懒加载,spring采用的是提前暴露对象的方法。

2.三级缓存解决循环依赖问题

20562d9a9ac04e1da8b74a0885eb1ada.jpg

 

①Spring容器初始化ClassA通过构造器初始化对象后提前暴露到Spring容器中的singletonFactorys(三级缓存中)。

②ClassA调用setClassB方法,Spring首先尝试从容器中获取ClassB,此时ClassB不存在Spring 容器中。

③Spring容器初始化ClassB,ClasssB首先将自己暴露在三级缓存中,然后从Spring容器一级、二级、三级缓存中一次中获取ClassA 。

④获取到ClassA后将自己实例化放入单例池中,实例 ClassA通过Spring容器获取到ClassB,完成了自己对象初始化操作。

⑤这样ClassA和ClassB都完成了对象初始化操作,从而解决了循环依赖问题。

3.Bean的注解

@Component 通⽤的注解,可标注任意类为 Spring 组件

@Service 在业务逻辑层使用(service层)

@Repository 在数据访问层使用(dao层)

@Controller 在展现层使用,控制器的声明(controller层)

 

​●注入bean的注解

@Autowired:默认按照类型来装配注入,@Qualifier:可以改成名称

@Resource:默认按照名称来装配注入,JDK的注解,新版本已经弃用

 

●@Autowired注解原理

@Autowired的使用简化了我们的开发,实现 AutowiredAnnotationBeanPostProcessor 类,该类实现了 Spring 框架的一些扩展接口。​ 实现 BeanFactoryAware 接口使其内部持有了 BeanFactory(可轻松的获取需要依赖的的 Bean)。​ 实现 MergedBeanDefinitionPostProcessor 接口,实例化Bean 前获取到 里面的 @Autowired 信息并缓存下来;​ 实现 postProcessPropertyValues 接口, 实例化Bean 后从缓存取出注解信息,通过反射将依赖对象设置到 Bean 属性里面。

 

●@SpringBootApplication注解等同于下面三个注解:

 

✮@SpringBootConfiguration: 底层是Configuration注解,说白了就是支持JavaConfig的方式来进行配置

✮@EnableAutoConfiguration:开启自动配置功能

✮@ComponentScan:就是扫描注解,默认是扫描当前类下的package

4.@SpringMVC

@Controller 声明该类为SpringMVC中的Controller

@RequestMapping 用于映射Web请求

@ResponseBody 支持将返回值放在response内,而不是一个页面,通常用户返回json数据

@RequestBody 允许request的参数在request体中,而不是在直接连接在地址后面。

@PathVariable 用于接收路径参数

@RequestMapping("/hello/{name}")申明的路径,将注解放在参数中前,即可获取该值,通常作为Restful的接口实现方法。

●SpringMVC原理

63c8d7b9bcdf46a6892d12714f147ee2.png

 

①客户端(浏览器)发送请求,直接请求到 DispatcherServlet 。

②DispatcherServlet 根据请求信息调⽤ HandlerMapping ,解析请求对应的 Handler 。

③解析到对应的 Handler (也就是 Controller 控制器)后,开始由HandlerAdapter 适配器处理。

④HandlerAdapter 会根据 Handler 来调⽤真正的处理器开处理请求,并处理相应的业务逻辑。

⑤处理器处理完业务后,会返回⼀个 ModelAndView 对象, Model 是返回的数据对象

⑥ViewResolver 会根据逻辑 View 查找实际的 View 。

⑦DispaterServlet 把返回的 Model 传给 View (视图渲染)。

⑧把 View 返回给请求者(浏览器)

5.@SpringMybatis

@Insert : 插入sql ,和xml insert sql语法完全一样

@Select : 查询sql, 和xml select sql语法完全一样

@Update : 更新sql, 和xml update sql语法完全一样

@Delete : 删除sql, 和xml delete sql语法完全一样

@Param : 入参

@Results : 设置结果集合@Result : 结果

@ResultMap : 引用结果集合

@SelectKey : 获取最新插入id

 

Q:mybatis如何防止sql注入?

A:简单的说就是#{}是经过预编译的,是安全的,${}是未经过预编译的,仅仅是取变量的值,是非安全的,存在SQL注入。在编写mybatis的映射语句时,尽量采用**“#{xxx}”这样的格式。如果需要实现动态传入表名、列名,还需要做如下修改:添加属性statementType="STATEMENT",同时sql里的属有变量取值都改成${xxxx}**

●Mybatis和Hibernate的区别

 

✮Hibernate 框架:

Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,建立对象与数据库表的映射。是一个全自动的、完全面向对象的持久层框架。

 

✮Mybatis框架:

Mybatis是一个开源对象关系映射框架,原名:ibatis,2010年由谷歌接管以后更名。是一个半自动化的持久层框架。

 

●区别:

★开发方面

在项目开发过程当中,就速度而言:

hibernate开发中,sql语句已经被封装,直接可以使用,加快系统开发;

Mybatis 属于半自动化,sql需要手工完成,稍微繁琐;

但是,凡事都不是绝对的,如果对于庞大复杂的系统项目来说,复杂语句较多,hibernate 就不是好方案。

 

★sql优化方面

Hibernate 自动生成sql,有些语句较为繁琐,会多消耗一些性能;

Mybatis 手动编写sql,可以避免不需要的查询,提高系统性能;

 

★对象管理比对

Hibernate 是完整的对象-关系映射的框架,开发工程中,无需过多关注底层实现,只要去管理对象即可;

Mybatis 需要自行管理映射关系


http://www.ppmy.cn/news/1535074.html

相关文章

Linux:Linux进程概念

✨✨✨学习的道路很枯燥,希望我们能并肩走下来! 文章目录 目录 文章目录 前言 一 冯诺依曼体系结构 二 操作系统(Operator System) 2.1 概念 2.2 设计OS的目的 ​编辑 2.3 OS如何进行管理 ​编辑2.4 总结 三 进程的标示符 3.1 基本概念…

物联网开发中上位机、下位机、服务器区分

在物联网(IoT)开发中,一个完整的项目通常由三个主要部分组成:上位机APP、设备端和服务器。这三个部分各自承担不同的角色,并且相互协作以实现整个系统的功能。 下面将对这三者进行详细介绍: 上位机APP: 定义…

ubuntu双网卡下,一个用外部网络,一个用内部网络

当ubuntu中双网卡时,可能存在问题是一个接外网无法ping通,或者一个接内外无法ping通因为是没有路由告诉ubuntu应该访问哪个网卡。在/etc/rc.local中添加: route add -net 0.0.0.0/0 enp0s8 route add -net 0.0.0.0/0 gw 192.168.1.1 route ad…

QT中的按钮控件和comboBox控件和spinBox控件无法点击的bug

如图所示的.ui,执行却无法点击,需要删除布局,重新布局,并且QGroupBox放到后面。

python中的copy方法

记录一下python中的浅拷贝copy和深拷贝deepcopy 例题如下: import copyls [1, 2, [3, 4], 5, 6]ls1 ls.copy()ls2 lsls3 copy.deepcopy(ls)ls[2][1] 0ls.pop(1)ls.append([7, 8])print(ls1) #--------慙1慖print(ls2) #--------慙2慖print(ls3) #------…

【运动控制】关于GPIO的NPN型输入与NPN漏型输入

【运动控制】关于GPIO的NPN型输入与NPN漏型输出 1.背景2.NPN型输入3.NPN漏型输入 1.背景 NPN型和NPN漏型都是与NPN晶体管相关的术语,但它们在电路应用和连接方式上有一些差异。 一般来说,GPIO的通用输入采用NPN型,而通用输出采用的是NPN漏型…

滚雪球学MySQL[2.3讲]:MySQL数据过滤与排序详解:WHERE条件、ORDER BY排序与LIMIT分页查询

全文目录: 前言2.3 数据过滤与排序1. WHERE 条件语句基本语法示例1:筛选符合特定条件的数据示例2:使用LIKE进行模糊查询示例3:使用IN操作符示例4:使用AND与OR组合条件示例5:范围查询 2. ORDER BY 排序基本语…

在登陆功能中添加Redis缓存

目录 基于Redis实现短信登录 实现流程图 实现代码 解决登录状态刷新问题 初始方案思路: 实现代码 发送验证码 登陆实现 如果是新用户则自动创建 运行测试 基于Redis实现短信登录 实现流程图 实现代码 Overridepublic Result login(LoginFormDTO loginForm…