StringRedisTemplate和RedisTemplate区别和联系
1、首先要明白java序列化的概念,java序列化是指:将java对象通过某种方式转换成可以在网络中传输的字节数组。同样的反序列化是指:将字节数组转换成java对象。

2、再来看这两个类StringRedisTemplate和RedisTemplate,这两个类是springboot-data-redis对Redis进行操作的实现类。
打开StringRedisTemplate和RedisTemplate的源码,发现StringRedisTemplate继承了RedisTemplate,一般来说子类应该比父类有用更强大的功能,而此处却不是,因为RedisTemplate是泛型类,而在StringRedisTemplate继承RedisTemplate类时,则是指定了泛型的类型,两个String。
这就直接导致了,StringRedisTemplate只能处理String-String的键值对数据,而RedisTemplate则可以处理任何类型的键值对。


3、事实也是如此,比如我们在程序中注入StringRedisTemplate后,使用其set方法(template.opsForValue().set(String,String))存储一个实体对象时,则会报错,因为set方法的两个参数全是String。

4、再来说说两者的序列化:StringRedisTemplate里面有一个无参构造方法,意思是重新创建一个RedisSerializer,即StringRedisSerializer。
而RedisTemplate的序列化则是使用的JdkSerializationRedisSerializer。正如上面所说的,java数据要和redis数据库进行交互时,java程序正是通过这两个类实现的序列化和反序列化。


5、我们再来看JdkSerializationRedisSerializer和StringRedisSerializer的实现,发现两者都有序列化和反序列化的方法,两者的不同点在于一个是对Object对象进行的序列化和反序列化,另一个是对String的序列化和反序列化。
StringRedisSerializer设置了编码方式UTF-8,支持世界上所有的语言,是通过new String和getBytes实现的,这个不难理解,我们平时也会接触到,比如在文件的读写操作中。

6、比较难理解的是JdkSerializationRedisSerializer。且看hasKey方法的调用过程,rawKey就是进行序列化的方法,一路向下找,
最终调用的是JdkSerializationRedisSerializer.serialize,


7、而JdkSerializationRedisSerializer又调用了SerializingConverter类的convert方法。在这个方法里其转换主要有三步:
1、ByteArrayOutputStream(1024),创建一个字节数组输出流缓冲区。
2、DefaultSerializer.serialize(source, byteStream):把要序列化的数据存储到缓冲区。还想看他是怎么放到缓冲区的,但是,能力有限,水平一般,serialize的细节,实在无能为力,看了半天,还是氐惆。
3、toByteArray:就是把上一步放到缓冲区的数据拷贝到新建的字节数组里。
至此Object的序列化就结束了,返回了一个字节数组。
