delphi查找控件:在页面方法执行或者控件方法执行中查找性能瓶颈

在很多时候我们需要调整网站的性能,通过iis日志分析网站的执行速度,在执行速度有问题时,我们不得不调试,调试的时候就用到了当前页面的执行时间。

我站点中的所有网页都从一个PageBase继承,所以我把统计执行时间的功能放到了PageBase中,首先我声明一个long类型的成员变量_startTimeTicks,此成员变量记录开始执行的时间Tick,在页面Render完成时我再用DateTime.Now.Ticks减去开始的startTimeTicks,这样便得到了整个页面的执行时间。

1 public class PageBase : Page
2 {
3 protected long _startTimeTicks;
4
5 protected override void _disibledevent= DateTime.Now.Ticks - _startTimeTicks;
28 return ticks;
29 }
30 }
31 #endregion
32 }
33
这样PageBase基类就有了,他里面有两个Public的属性,可以随时记录执行到某个方法的时间段,这样对于调试程序,查看性能瓶颈很有用。

1 public class _Default:PageBase
2 {
3 protected void Page_Load(object sender, EventArgs e)
4 {
5 SomeClassInstance.method();
6 #if DEBUG
7 this.Controls.Add(new LiteralControl(ExecTime));
8 #endif
9 SomeClassInstance.methodA();
10 #if DEBUG
11 this.Controls.Add(new LiteralControl(ExecTime));
12 #endif
13 }
14 }同样如果怀疑某个控件的执行中有可能有性能瓶颈,也可以统计它的方法的执行时间 public class ControlA : UserControl
{
protected PageBase PageBase
{
get
{
return Page as PageBase;
}
}

protected override void OnLoad(EventArgs e)
{
SomeMethodA();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));

SomeMethodB();
this.Controls.Add(new LiteralControl(PageBase.ExecTime));

base.OnLoad(e);
}
}
Tags:  activex控件 gridview查找控件 查找控件 delphi查找控件

延伸阅读

最新评论

发表评论