当前的数据表存在一个 metablock,里面会记录表中每个字段的 minmax 值,查询或者插入数据时,minmax 值会以 byte 数组的方式存储在内存中
考虑到字段是 String 类型且长度过长时,在插入数据或者做查询时 minmax 数组会占用过多内存。因此对 minmax 数组的长度做了裁剪,从而希望达到减少内存占用的效果
现在想测试在代码修改以后内存的占用确实减少了,应该怎么处理呢?
我本来想打 jmap 查看做查询和插入数据时 byte 数组的大小,但 jmap 打出来的 byte 数组大小不止有 minmax 数组的影响,服务器节点上还会有其它数据对 byte 数组的大小产生影响吧?而且考虑到代码运行过程中会作 GC,似乎没办法通过 jmap 测试得到结论,还有什么其它的办法吗?
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.