欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

Weblogic的JSP问题解决方法(1)(2)

来源: javaer 分享于  点击 903 次 点评:104

问题3:

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

解决方法:

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

问题4:

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

解决方法:

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

同时在捕捉错误的时候要写明程序名称,方便查找,这一点做的还不够。

最好能写一个记录log的方法,以便程序调用。

问题5:

改善性能,提高速度。

具体实例:

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

for(int I=0; I

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

int size = v.size(); for(int I=0; I( v.get(I).getClass().toString()); }

虽然这是一个简单的改动,但它仍旧赢得了性能。毕竟,每一个CPU周期都是宝贵的。

问题6:

在JSP文件里面 不要写 <%@ page import="java.lang.*" %>

因为java 不需要引入此包就可以引用里面的类文件。

问题7:

使用vector+hashtable 一次返回查询结果resulset.

解决方法:

记录集:将一条记录放到一个hashtable里面,然后把它再添加到vector里面,循环记录下结果集,返回vector具体见后面的Java文件的部分代码不包扩数据库的连接和关闭)

package zjdx.bean.common;

/********************************************
***** Title: hashtable_vector_rs 
***** Description: 数据显示 
***** Copyright: Copyright (c) 2002 
***** Company: DHC 
***** author: wangyl 
***** version: 1.0 
***** 说明:
***** 记录集:一条记录用放到一个hashtable里面,然后把它再
放到vector里面,循环记录下结果集,返回vector

*********************************************/

import java.io.*;
import java.sql.*;
import java.util.*;
import java.text.*;

public class hashtable_vector_rs
{
/*----------------------------------------------------------------*/
/* 函数名称: getMultiRowInfo
/* 功能描述: 返回记录集,放到Hashtable里面
/* 参数: sql 语句,字段个数
/* 返回值: 成功---htable, 失败---null
/*----------------------------------------------------------------*/
public Vector ListResult(String sqlStatement,int num)
{
Vector ListRs=new Vector();

try
{
connectDB();
rs=stmt.executeQuery(sqlStatement);
//判断字段数据类型 
//date型 返回 93 
//int型 返回 2,4
//bigint型 返回 3 
//String型 返回 12
//(char 型)返回 1
int t = -1;
rsmd = rs.getMetaData();
int ColumnCount=0;
if(num>0)
ColumnCount = num;
else
ColumnCount = rsmd.getColumnCount();
while(rs.next())
{ 
Hashtable htable =new Hashtable();
for (int i = 1; i <= ColumnCount; i++) 
{
t=rsmd.getColumnType(i);
System.out.println("i="+i+",t="+t+"name="+rsmd.getColumnName(i)); 
if(t==12||t==1||t==3)
{
if(rs.getString(i)==null|| rs.getString(i).equals(""))
htable.put(rsmd.getColumnName(i),"");
else
htable.put(rsmd.getColumnName(i),rs.getString(i));
}
else if(t==93)
{
htable.put(rsmd.getColumnName(i),rs.getDate(i).toString());
}
else if(t==2||t==4)
{
htable.put(rsmd.getColumnName(i),Integer.toString(rs.getInt(i)));
}
}
ListRs.add(htable);
}//e
return ListRs; 
}
catch(Exception listError)
{
System.out.println("数据库操作失败!"+listError);
return null;
} 
finally
{
try
{
closeDB();
} 
catch(Exception closeErr)
{
System.out.println("关闭数据库出错:"+closeErr); 
}
} 
}
}

问题8:

JSP的程序也有设计的不够合理的地方。

例如:选择一个下拉框,提交一次,列出所选的数据,选择另外一个下拉框再次提交,再次列出所选的数据。

解决方法:

尽量一次把条件选择完毕,然后列出所选择的数据,并且在数据多的时候,尽量使用翻页,减少运行时间。


相关栏目:

用户点评