分享
 
 
 

Java性能探寻

王朝java/jsp·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

在开发www.jobcn.com的期间,系统在运行的时候出现了一些问题,现将我的问题解决方法做一个小结,供以后作项目的参考。并请大家不吝指教.

问题1:

Resin 的数据库连接数目在程序运行中不断增长,最后连接数目超过最大数,导致Resin服务关闭

原因:

在操作完数据库后,没有关闭数据库连接;或者是返回结果集(Resultset),而无法在jsp中关闭数据库连接。

解决方法:

1. 在操作完数据库要关闭数据库连接。

2. 尽量不要返回结果集Resultset, 可以返回Vector(一个字段)、Hashtable(多个字段),这样可以在Javabean中关闭数据库。

3. 假如javabean中返回的是结果集(Resultset),也可以在javaBean中写一个connectDB(连接数据库)、closeDB(关闭数据库)的方法,然后JSP里面调用connectDB(),建立数据库连接,同时就可以对数据库进行操作了,操作数据库完毕,可以通过closeDB() 来关闭数据库。

4.关闭连接时尽量使用conn.close(),rs.close().....而不要另外写方法去关闭它,如调用DB.closeConnection(conn)等等,这样其实对性能有一定影响,因为该性能经过了我对单个文件的测试.

5.关闭连接时请按顺序进行,如rs.close()..,stmt.close()..conn.close()....

问题2:

在运行某一个JSP 程序的时候,Resin 的内存陡然增长,而且居高不下。最终导致Resin 内存不足,甚至当机。

原因:

过度使用内存。

解决方法:

1. 由于数据量比较大,在对字符串进行操作的时候,使用 + 进行字符串连接,而

相信大家对String都非常熟悉,我们也经常要用它来做字符串的连接什么的,例如:

String a =b+c file://b,c 都是String

但是在实际的编译中却是这样:

String a=new StringBuffer().append(b).append(c).toString() 显然,在一个简单的语句中却意外的多生成了2个对象:

.StringBuffer()

.toString返回的一个String

我们比较一下这两段程序的性能:

程序片断一:

StringBuffer s=new StringBuffer();

long start = System.currentTimeMillis();

for (int i=0;i<10000;i++){

s1+="a";

}

long stop = System.currentTimeMillis();

System.out.println(stop-start);

程序片断二:

StringBuffer s=new StringBuffer(10000);//

long start=System.currentTimeMillis();

for (int i=0;i<10000;i++){

s.append("a");

}

long stop=System.currentTimeMillis();

System.out.println(stop-start);

比较一下结果,差距很明显。

至于为什么String的连接这么做,因为String无法直接改变其长度,而必须采用StringBuffer的用法。

因此建议使用StringBuffer 的append 方法来进行字符串相连。

2. 在解决这个问题的时候,我也尝试使用上面的方法,效果并不是很明显(消耗内存上)。后来在显示大量数据的时候,避免字符串相连的步骤,而直接使用out.println(),直接输出。

问题3:Java并不阻止程序占用过多的内存,当对象向堆所请求的内存不足时,垃圾收集器(Garbage Collector)就会自动启动,释放那些引用数为零的对象所占用的内存,Java也不会自动释放无用的对象的引用,假如程序忘记释放指向对象的引用,则程序运行时的内存随着时间的推移而增加,发生所谓内存泄漏(memory leaks),创建对象不但消耗CPU的时间和内存,同时,为释放对象内存JVM需不停地启动垃圾收集器(Garbage Collector),这也会消耗大量的CPU时间。

解决方法: 由于在运行一段时间JSP程序后,Resin 的内存会有一个缓慢的增长,这样也会导致内存溢出,为了避免这总现象的出现,最终的解决方法是: 编写一个servlet程序,在启动服务器的时候,启动一个这个servlet,每隔20分钟运行在服务器端运行一次,来定时回收内存。

问题4:

log文件里面的调试信息没有注释去掉。

解决方法:

在程序通过后,尽量把调试的信息注释去掉。

同时在捕捉错误的时候要写明程序名称,方便查找.

问题5

改善性能,提高速度。

具体实例:

我们再来看一个有关Vector类的代码片段:

for(int I=0; I<v.size(); I++) { System.out.println( v.get(I).getClass().toString()); }

假如v包含100,000个元素,这个代码片段将调用v.size()方法100,000次。虽然size方法是一个简单的方法,但它仍然需要一次方法调用的开销,至少JVM需要为它配置以及清除堆栈环境。在这里,for循环内部的代码不会以任何方式修改Vector类型对象v的大小,因此上面的代码最好改写成下面这种形式:

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有