帮忙分析一下一小段代码

nailgo 2006-06-30 01:48:06
说明:死循环,每隔60秒update一下数据库。已经测试过可以运行,内存占用最大6M,最小300k(看资源管理器的java.exe进程)。但觉得不太对头。
请问,这样是不是每循环一下都会创建新的Connection和Statement对象?conn和stmt在close之后是否还占用资源?用sleep暂停程序有没有问题?

for (;;){

try{
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@10.10.10.10:1394:test","admin","pass");
Statement stmt = conn.createStatement();
stmt.executeQuery("update testtable set scantime='"+systimes+"' where id = 'my'");]
stmt.close();
conn.close();
} catch(SQLException e){
e.printStackTrace();
}
try{
Thread.currentThread().sleep(60000);
}catch(InterruptedException ex){
ex.printStackTrace();
}

}
...全文
281 11 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
商科程序员 2006-06-30
  • 打赏
  • 举报
回复
还会报“不可到达的代码”错误
不会吧,如果是真的,那就在循环中加入一个跳出的条件,条件永远不满足就行了.
nailgo 2006-06-30
  • 打赏
  • 举报
回复
close()也写在循环外面,那就没用了,会一直连着数据库。还会报“不可到达的代码”错误
it_fk 2006-06-30
  • 打赏
  • 举报
回复
把close()也写在循环外面不就行了
nailgo 2006-06-30
  • 打赏
  • 举报
回复
如果创建对象的语句不写到循环里,那close了之后怎么恢复?总不能一直连着数据库的吧?
CEO_ZHU 2006-06-30
  • 打赏
  • 举报
回复
不要写到For循环里面就可以了
nailgo 2006-06-30
  • 打赏
  • 举报
回复
哦,是啊,那能不能做到只建一次对象呢?
kevinliuu 2006-06-30
  • 打赏
  • 举报
回复
你可以把DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());写在for循环外面,registerDriver做一次不可以吗
nailgo 2006-06-30
  • 打赏
  • 举报
回复
有没有更好的方法啊
nailgo 2006-06-30
  • 打赏
  • 举报
回复
kevinliuu(@。@) ,那就是说这样写也没什么问题了吧
humin595 2006-06-30
  • 打赏
  • 举报
回复
不明白!
kevinliuu 2006-06-30
  • 打赏
  • 举报
回复
请问,这样是不是每循环一下都会创建新的Connection和Statement对象?

是的

conn和stmt在close之后是否还占用资源
close之后应该通知gc回收了

用sleep暂停程序有没有问题?
没有

62,634

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧