spring @lazy注解的使用 spring @lazy注解的使用在spring中@lazy注解表达延迟的含义,但在不同情况下,这里的延迟并不是同一层意思。下面将描述我发现的两层含义。 1. 延迟初始化bean 首先我们知道,容器启动之前会扫描所有的class文件,并将需要加载到容器中的类,整理成BeanDefinition存储。容器启动时将依次将BeanDefinition构建成bean,构建过程中同时解决依赖注入和循环 2022-05-11 #spring #springboot #技巧
jackson序列化优先级和注解顺序 jackson序列化优先级和注解顺序先说结论: 序列化时getter方法优先于字段,注解添加到字段上或添加在getter方法上同样生效。 1. 创建serializerProvider调用serializeValue方法12345678910111213141516protected final void _writeValueAndClose(JsonGenerator g, Object 2022-04-19 #jackson
spring中ObjectFactory , ObjectProvider 和 FactoryBean spring中ObjectFactory , ObjectProvider 和 FactoryBeanObjectFactory , ObjectProvider这两个类是spring的提供的工厂方法的辅助类,ObjectFactory在 1.0.2版本添加进去的,他只有一个getObject方法ObjectProvider在4.3版本添加,它继承了ObjectFactory接口,添加了更多方法, 2022-03-26 #spring #ObjectFactory #ObjectProvider #FactoryBean
project reactor中的onErrorXxx操作符 project reactor中的onErrorXxx操作符 reactor项目中存在很多操作符其中一些与处理异常有关的操作符,它们都以onError开头,一共五个下面我们逐个分析他们。 onErrorMap onErrorResume onErrorReturn onErrorContinue onErrorStop 三个是用来处理上游传递的错误信号这三个是一组的,他们原理类似,分别是: 2022-03-17 #reactor #onErrorMap #onErrorResume #onErrorReturn #onErrorContinue #onErrorStop
mybatis dynamic查询指定字段 mybatis dynamic查询指定字段 使用mybatis dynamic做查询是,通常情况下会查询所有字段,因为多查几个字段对性能影响不会很大。但是有些情况下,查询记录数量较多,多查的字段就有很大的影响了。此时我们希望只查询指定的字段。 第一种写法一般写法是这样的 123testMapper.selectMany(MyBatis3Utils.select(columns,test, ds 2022-03-07 #mybatis #mybatis dynamic
reactor中的线程池 reactor中的线程池1.DelegateServiceScheduler将任务委托给底层单个线程池,和直接使用线程池无本质区别。 2.SingleScheduler单线程的scheduler,和java自带的一致。 3.ImmediateScheduler在主线程执行的scheduler。 4.ParallelScheduler此scheduler会将任务均匀分配给内部的单线程线程池执行, 2022-01-17 #flux #线程池 #reactor
Flux parallel操作符的用法 Flux parallel操作符1. parallel操作符 parallel操作符执行过后,会生成一个新的flux 即parallelFLux。他能够接受多个订阅者,他会从原始flux中请求perfetch个元素,将上游传递push过来的元素依次按顺序分配给子订阅者。 分配上游元素过程是:依次分配给下游每个订阅者,当某个子订阅者请求数已经满足时,将跳过此订阅者继续向下一个子订阅者分配。 2022-01-17 #flux #reactor #parallel
mybatis实现真流式查询mysql mybatis实现mysql流式查询的原理背景如果使用mybatis查询mysql,查询结果集非常大时,可能发生oom,我们可以使用mysql的流式查询,按需逐行查询每条数据,实现低内存占用。下面分析其原理。 jdbc驱动如何支持流式查询的jdbc驱动的基本原理 jdbc驱动与mysql之间建立tcp连接,将sql语句发送到mysql服务端后,并从mysql服务端读取数据,并封装成resultS 2022-01-11 #mysql #mybatis #mysql流式查询技巧 #技巧
批处理当前脚本目录和当前命令行目录 批处理当前脚本目录和当前命令行目录当前脚本目录使用%~dp0获取,无论在哪里执行,此值是不变的。当前命令行目录使用%cd% 获取相当于shell中的pwd命令,返回当前命令所在目录 参考下面脚本的结果,保存脚本时请使用ANSI编码保存,否则中文乱码 123456789101112131415@echo off set root=%~dp0echo 当前脚本目录: %root%set pwd=%c 2021-10-22 #cmd #批处理 #windows
groovy静态编译容易引发的问题 groovy静态编译容易引发的问题groovy为了提高性能,有一个静态编译的注解@CompileStatic,在类上添加该注解后,编译出来的class文件会更加静态化,更像java文件编译出来的class字节码。但是因此会导致一些问题,今天我就遇到一个,下面将其记录下来。 众所周知,groovy是动态类型的,如下面重载的函数,使用java调用和groovy调用结果是不同的。 1. 测试groovy 2021-10-16 #groovy #java #静态编译 #双层闭包