C# aspx事件响应缓慢 原因
2017-01-07 09:35
162 查看
问题描述 在考试界面 的交卷按钮 如图
,试卷做完之后,点击交卷,发现响应时间很慢很慢,它既不报错,也不出界面,而且只要这个界面处于无法响应的状态,其他界面就否想打开。这就是一个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"]); 完美解决问题。
,试卷做完之后,点击交卷,发现响应时间很慢很慢,它既不报错,也不出界面,而且只要这个界面处于无法响应的状态,其他界面就否想打开。这就是一个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"]); 完美解决问题。
相关文章推荐
- Android中ListView的item不能响应点击事件的原因
- android 自定义listview无法响应点击事件OnItemClickListener的原因
- vue中onscroll事件没有响应的原因
- android 自定义listview无法响应点击事件OnItemClickListener的原因
- button的onclick事件在360浏览器中不响应,但在IE中可以,不明白原因
- win32程序不响应鼠标双击事件的原因
- Android中ListView的item不能响应点击事件的原因
- Android中ListView的item不能响应点击事件的原因
- listview oclick事件不响应原因
- updatepanel下dropdownlist不能响应selectindexchanged事件的原因(很傻比)
- h5开发app,移动端 click 事件响应缓慢的解决方案
- textview 不响应事件的原因。没有给控
- UpdatePanel中事件无响应原因之一
- Android中ListView(gridview)的item中有button等子点击控件时不能响应点击事件的原因
- Android中Fragment点击事件的添加(及点击事件无响应的原因)
- 事件响应,让网页交互
- robotium(及百度cafe)运行testcase之后程序挂起没有响应的原因调查及解决
- flex偶尔监听不到事件的原因
- 响应事件的示例
- Android中双击,三击事件的响应代码