之前遇到一个场景,在前公司,同事在批量查询数据转储的时候,应用频发的出现fullGc,内存溢出等异常日志。当时观看同事写的代码,是在循环内的创建对象,接收DB查询结果再返回。
于是建议同事,讲创建对象过程放在循环外。部署,测试,果然好了。当时天真的断定就是循环内创建的对象会重复占用内存。
后来在下家公司,某同事同样出现这种问题,也是在循环内创建的对象。同时内存溢出。于是断定便是写法问题。但是同时反驳,没有区别。当时为了说服同事,自己本地写了demo发现,确实在循环外,循环内创建对象,内存使用并没有区别。于是困惑了。明明之前的经历已经验证了。循环内对象是频繁创建对象,会触发GC的。为什么现在又不会呢。
不久前看到关于逃逸分析与栈上内存分配问题才了解
如果启用逃逸分析是可以回收分配在栈上的对象的。函数体运行完即销毁对象,
如果关闭,则不会回收。会频繁创建内存,但不会执行完后销毁,并且触发GC。