问题描述 在考试界面 的交卷按钮 如图 ,试卷做完之后,点击交卷,发现响应时间很慢很慢,它既不报错,也不出界面,而且只要这个界面处于无法响应的状态,其他界面就否想打开。这就是一个bug。
说句实话,在这几天都一直怕处理这个问题。一直在逃避。我觉得这个问题它不是bug,不报错,我怎么去解决,所以就有点怕 。本打算等陈聪儿来,请教一下他,结果他这几天都挺忙,没办法,毕竟是自己面前的事。不处理不行。 于是就硬着头皮搞。
最开始从chapter.aspx.cs 界面开始看。问题就是 我想找到究竟是哪句话 或者哪个方法让这个方法不执行。
在这个界面 找到 随机抽取10道 的代码。并且找到按钮的响应方法,它写在 JavaScript 里面,方法体是goexam() 关键性代码就是
jQuery.ajax({
url: "?action=goexam&classid=" + classid , success: function (d) {
top.location.href = "/exam/training.aspx?id=" + d;
}
用 ajax 传参 ,并且成功之后,就进行跳转。
到了training.aspx界面,这个界面执行 base.Response.Redirect("/exam/TrainingSubmit.aspx?id=" + this.sjId)这个语句。这就话就是跳转到submit 界面,于是我在这个界面就去检查 ,id 是否传过来了,发现都有值。
试卷提交界面 TrainSubmit.aspx.cs 方法执行顺序,每个方法执行速度都很快,于是继续往下看,
Page_Load->method_1()->method_2()->hisreport.aspx 这个界面相当慢
Hisreport.aspx.cs 界面方法的执行顺序 Page_Load()->this.Trainlist()->this.method_0() ,到此就找到原因了。这个方法method_0()执行的速度是相当慢,于是就在这个方法里面不停的打断点,每次都运行进来,一句代码一句代码的读,因为想知道原因,必须清楚那句话是干啥的,为么我自己要看呢,因为我深知没有人会帮我解决这个问题,如果只是装装样子,混时间过日子,我大可不必自己看,还是硬着头皮自己看。发现了一句话
DataRow[] dataRowArray = sJTypeClass.Select(string.Concat("Depth=2 and SJClassId=", classid)); 这句话的classid 值为0,我去数据库查询的时候,这个dataRowArray 查出来了2419条数据,
看这两句话
DataRow[] dataRowArray1 = dataRowArray;
for (int i = 0; i < (int)dataRowArray1.Length; i++)
就是把上面查询的dataRowArray 赋值给dataRowArray1 ,然后用dataRowArray1 的长度进行循环,那么这条循环语句,就执行了2419次,所以每次程序执行到这里的时候,就崩溃了。我先在
DataRow[] dataRowArray = sJTypeClass.Select(string.Concat("Depth=2 and SJClassId=", classid)); classid 换成一个常量,1180,运行一下,那个界面一秒钟就出来了,于是找到了原因, 因为这个classid没有被赋值,于是在恰当的位置添加一条赋值语句。this.classId = Utils.StrToInt(item["ClassID"]); 完美解决问题。