在计算机高级语言中,字节属于最小单位,例如在Java中,int占用4个字节,long占用8个字节等。基本上所有基本类型(包括String)都可以转换成字节,那么这到底有何作用,本篇博客主要是记录了我使用字节数组的经验,希望可以给大家提供一些思路。
缓存对象
缓存类型大小分析
在实际开发中,经常会用到本地缓存,或使用Redis
或者Memcached
来作分布式缓存,Java一般存入缓存中的对象无非是以下几种:
- 序列化的Java对象:一个Java对象序列化后所占用的字节是按对象中属性个数,方法个数,以及属性的值决定,最小也需要几百个字节来存储,大的话可能需要几万个字节
- String(可能是json串):占用字节由字符串的长度决定
规则的byte[]数组:占用字节由数组长度决定,相比较于String来说,基本类型转换成固定字节的数组,而不是转换成内容长度的String,故字节数组所占用的字节比String更少
上述的占用字节数是不考虑Redis或Memcached内部会做出的压缩操作。
从上面三种对象分别占用的字节数来分析得出结论:
- 在大量的缓存数据(亿级以上)的情况下,为了提高空间利用率,切勿将Java对象当做缓存的内容
- 字节数组所需空间最少
字节数组的使用实例
下述场景属于个人虚构的
场景:在电影票系统数据库中,电影院id为int类型,电影id为int类型,上映时间为long类型,电影名称为String类型,现有10亿数据,需要将这些数据存入Redis
中。
分析:10亿数组采用Java对象作为存储数据显然是不可取,而上映时间为long类型,可能出现数字非常大的id,所以准备采用字节数组形式存储。
实现:
1 | // 缓存结构为:采用hash结构,电影院id为key,电影id为hashKey,value为字节数组,内容为:上映时间+电影名称,存储为大小为8+String.getBytes().length |
当使用本地缓存需要提高内存的利用率,也是可以使用字节数组的。
推荐一篇博客:java Byte和各数据类型(short,int,long,float,double)之间的转换
字节数组的作用
- 提高空间利用率
- 压缩内容,在网络传输时,能有效压缩传输数据的大小,从而提高效率
以上内容纯属个人见解,有不妥的地方请各位大神指正,谢谢!