最近在写一个采用json数据格式传输的接收程序,该程序基于Netty编写,将接收到的数据解析成java对象,由于业务关系,每个json字符串长度达到了20M,下面是解析代码
byte[] readData = new byte[readableLength];
in.readdata(readData,0,readableLength); //in 为NIO对象,读取数据输入
String jsonStr = new String(readData); //用于解析的JSON字符串
当接收到json字符串时就要new 一个String对象用于解析,由于每个json字符串达到了20M,当有多个客户端连结时,将占用
过多的内存,同时,增加垃圾收集器的负担。
通过查看String 源码发现String内部是用一个 char value[] 来保存字符串,我们只需new 一个足够的大的String对象,并重用 value[] 内存区域,即可避免每次new String对象,并且减少垃圾收集器的负担,由于value[] 是 private final 类型,因此需要借助反射操作value[]。
下面是一段测试代码,每次new 一个2M大小的String并打印其中一部分字符串
char temp='a'; </