写了个Java程序,但总出现内存不足而退出,然后分析一下:
因为在Linux环境,用jdk自带的jmap工具(Linux/Unix环境特有的),可以对进程中的内存对象监视,然后就运行命令jmap -histo [pid],找内存中的对象数目变化。
程序运行一段时间之后,内存已经使用很大,jmap发现byte和int对象最多,程序中确实用了很多byte和int数组,然后手动设为null,但觉 着这种对象一般情况应该能自动回收才对,改完运行还是不行,再继续分析,发现Statement对象数目也比较多,感觉比较可疑,就找到数据库操作那块代 码,发现一个数据库连接不断的new Statement对象,没有close,加上close之后,问题解决了。
结论:数据库操作时从大到小是Connection,Statement,ResultSet对象,关闭了大的可以不关闭小的,但开着大的,就得关闭次大 的。如果用了连接池,连接的关闭是必须的,但是假断开连接,还必须关闭Statement或PreparedStatement等类型对象。