java的序列化和反序列化Serializable原理
背景实现Serializable接口就能把对象序列化反序列化出去,那么原理是什么呢?带着以下问题一探究竟
为什么实现这个接口就能序列化和反序列化呢?
序列化和反序列化的内容是什么呢,可以自定义吗?
为什么实现这个接口就能序列化和反序列化呢
java序列化代码 123456789public static void main(String[] args) throws IOException { Object o = new Serializable() { String strValue = "这是内容"; Integer intValue = 999; }; File file = new File(System.getProperty("java.io.tmpdir"), "serializable/"); ObjectOutputStream objectOutputStream = new ObjectOutputStream( ...
mybatisPlus分析Lambda语法原理
用lambda就不用写字符串了,这个对于开发业务来说,能减少很多的错误发生。尤其是字段写错了,数据库变更字段名了,等。用法如下
1eq(FissionCoupon::getMid, mid)
他会自动转换为mid,那他的原理是什么呢?原来他接受的是一个可序列化的Function对象
123@FunctionalInterfacepublic interface SFunction<T, R> extends Function<T, R>, Serializable {}
其实用到了jdk自带的序列化。因为lambda是个特殊的实例,也是个特殊的class。在序列化的时候lambda实例中有一个writeReplace方法。
可参考jdk的序列化 Serializable原理该方法的返回值是一个lambda描述对象,java.lang.invoke.SerializedLambda 1234567891011121314public final class SerializedLambda implements Serializabl ...
枚举序列化和反序列化的代码
在java或各种框架中,[反]序列化对枚举类型默认一般都是用的枚举的名称。如果代码有魔法值,我们想改成枚举类型。但我们在改造、重构后端的时候不想对前端或者第三方有影响,可以用到此方法。
必须用到的枚举工具类
参考通用枚举 通用枚举所有的枚举想要实现(反)序列化比较要用到通用枚举,实现通用枚举的接口即可
代码(最初版本)1.可反序列化的枚举
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768/** * 可反序列化的枚举 */public enum DeserializableEnum { // DBEnum是MybatisPlus枚举的adapter,增加了getDoc的方法。MybatisPlus是直接支持数据库[反]序列化的。但是还不支持和前端的[反]序列化的交互,所以在此配置即可。 DB_Enum(DBEnum.class, DBEnum::getVal ...
mvc枚举序列化和反序列化的配置
必须用到的枚举工具类
参考通用枚举 通用枚举
使用背景spring mvc 接收或者序列化枚举类型时,
默认是根据枚举的名称(string)进行序列化或者反序列化。但是在实际开发当中,我们一般用枚举代表某一个数值,数据库存储值。
同时我们也希望和前端交互用数值交互,而不是string名称。因此用到这个工具类支持以下几个组件的反序列化和序列化
spring convert@RequestParam@PathVariable...
jackson@ResponseBody
fastjsonJSON.parseObject(...)
代码
枚举序列化和反序列化的代码 枚举序列化和反序列化的代码
使用方式springConverter组件的使用spring 接收参数为form表单请求时,默认用的converter组件进行转换对象
12345678@Configurationpublic class AddEnumConverter implements WebMvcConfigurer { @Override public void addFormatters(For ...
通用枚举
使用场景我们一般用枚举来代表数字或者字符串,避免魔法值的产生。
有时需要根据数字或字符串获取到对应的枚举。
虽然可以在枚举里面写静态方法根据int获取对应的枚举也可以做到,但是你需要在一个枚举写一个方法,如果有N多个枚举则会非常的冗余类似于这段代码
123456789101112131415161718192021222324@Getterpublic enum Condition { ONCE(0, "满"), EACH_TIMES(1, "每满"), LADDERED(2, "阶梯满"); private final int code; private final String name; Condition(int code, String name) { this.code = code; this.name = name; } // 类似于这段代码 public static Condition getTypeByCode(int code) { ...
javaUtil动态代理
动态代理有很多使用的场景,比如
springAOP切入
spring事务、缓存
自定义业务场景等
本文就是一个动态代理util。为了使用起来更加的方便。之后的文章也有可能用得到。
后续用新文章来分析动态代理的原理
本文的使用场景(点我)
代码123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110import org.springframework.beans.BeanUtils;import org.springframework.cglib.proxy.Enhancer;import org.springframework.cglib.proxy.MethodInterceptor;i ...
环境变量
main方法参数使用:java 类名 【参数1】 【参数2】 【参数3】 .。。。
123public static void main(String[] args) { System.out.println(args);}
System.getenv获取系统环境变量同 linux 下 export
System.getProperty获取java程序变量通过 java -Dk=v配置
dubbo-spi
javaSpi
java有spi机制为什么dubbo还要自创一套?
javaSpi没有key value机制,没有顺序之分
javaSpi 如果有多个实现类,只能依次加载,不能精准加载
...等
dubboSPI的特性
可根据指定的key获取SPI实现
可根据@Activate注解进行分类,获取指定的SPI实现
多个实现可排序实现排序接口org.apache.dubbo.common.lang.Prioritized
可包装(静态代理)对原有的spi实现直接编码进行静态的代理,spi的实现类只留一个有参构造,参数为SPI接口的类型即可变为wrapper
可注入对spi的实现类中如果有set方法,且没有DisableInject注解,那么以此方法的第一个参数的类型+名称,再次从dubboSPI容器中寻找对应的实例。并set
spi无实现者的情况下,可自适应实现(一般开发者用不到)方法:getAdaptiveExtension()如果spi配置文件中的配置实现类上有Adaptive注解,则直接用此类。如果没有实现类,但是spi接口中个别方法上有Adaptive注解,并且参数 ...
java-spi
javaSPI机制service provider interface
12345// 通过遍历即可获取到对应的class,那么原理是什么呢?Iterator<ABC> iterator = ServiceLoader.load(ABC.class).iterator();while (iterator.hasNext()) { ABC next = iterator.next();}
原理java规定spi的配置文件都在这个目录META-INF/services/该目录下可以有多个文件,文件的名称必须以class全类名命名。通过ServiceLoader类,读取名字为spi类的全名称的文件内容为多行,一行为一个class的全类名。该class为spi的实现类。
ServiceLoader入口12345678910111213141516171819202122232425262728293031323334353637383940414243public final class ServiceLoader<S> implements ...