java JVM溢出 java.lang.OutOfMemoryError 解决方法


最近在处理大批量的原始数据,由于从数据中读取后,修改字段格式,然后插入数据库,造成内存溢出,总结一下原因,主要是在代码中运用了在循环中,String字符串相加,导致内存来不及清理,而溢出。解决方法是,在每次循环的开头,先清理一下String所占用的内存。


相关专业的解释是这样的:

String对象是不可改变的。每次使用 System.String类中的方法之一时,都要在内存中创建一个新的字符串对象,这就需要为该新对象分配新的空间。在需要对字符串执行重复修改的情况下,与创建新的 String对象相关的系统开销可能会非常昂贵。如果要修改字符串而不创建新的对象,则可以使用System.Text.StringBuilder类。例如,当在一个循环中将许多字符串连接在一起时,使用 StringBuilder类可以提升性能。

  通过用一个重载的构造函数方法初始化变量,可以创建 StringBuilder类的新实例,正如以下示例中所阐释的那样。

StringBuilder MyStringBuilder = new StringBuilder("Hello World!");


示例代码如下:

try {


pre = conn.prepareStatement(sql,ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);// 实例化预编译语句
// 执行SQL查询语句
rs1 = pre.executeQuery();
StringBuilder strb=new StringBuilder();
while (rs1.next()) {
XH++;
timeStr = str(rs1.getString("JGSJ"));
JGDD = rs1.getString("JGDD");
JGFX = rs1.getString("JGFX");
strb.setLength(0);
strb.append("insert into DAZHOU_GUOCHE1115 VALUES('").append(JGDD).append("','").append(JGFX).append("',to_date('").append(timeStr).append("','yyyy-mm-dd HH24:mi:ss'),'").append(XH).append("')");
//之前这里是用String字符串相加的形式,会占用内存
sta2.executeUpdate(strb.toString());


}
} catch (SQLException e) {
System.out.println(e.getMessage());
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值