给web网页加上生成时间,并在页面方法执行或者控件方法执行中查找性能瓶颈

在很多时候我们需要调整网站的性能,通过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 OnInit(EventArgs e)
 6         {
 7             _startTimeTicks = DateTime.Now.Ticks;
 9 
10             base.OnInit(e);
11         }
12 
13         #region 执行时间
14         public string ExecTime
15         {
16             get
17             {
18                 TimeSpan ts = new TimeSpan(DateTime.Now.Ticks - _startTimeTicks);
19                 return ts.TotalMilliseconds.ToString() + "ms";
20             }
21         }
22 
23         public int ExecTimeTicks
24         {
25             get
26             {
27                 long ticks = 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);
        }
    }
复制代码
posted @   玉开  阅读(3914)  评论(22编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示