用c#实现一个计算程序启动时间的构想

昨天同屋的兄弟来找我和森哥帮忙,说他的任务的问题,他需要做一个类似任务管理器的东西,能对系统中的进程进行监视,得到内存占用率和cpu占用率,由此来测试公司的某产品和word的性能差别,如启动时间,内存占用率等。他已经研究了半个月了,关于用c++如何实现,看着那些代码就头大,为了快速实现(反正无所谓用什么语言),森哥说,用C#,快!所以我就帮了他忙,查msdn,现写了一个小程序,作为需求分析吧,铺好路后就可以任车弛骋了嘛!以下是代码片断:

   1:  private void button1_Click(object sender, System.EventArgs e)


   2:  {


   3:      Process.Start("winword.exe");


   4:      


   5:      System.Diagnostics.Process[] myProcesses;


   6:      myProcesses = 


   7:          System.Diagnostics.Process.GetProcessesByName("foobar2000");


   8:      


   9:      String s = myProcesses[0].TotalProcessorTime.ToString()+"\n";


  10:      s += myProcesses[0].UserProcessorTime.ToString()+"\n";


  11:      s += myProcesses[0].PrivilegedProcessorTime.ToString()+"\n";


  12:      myProcesses = 


  13:          System.Diagnostics.Process.GetProcessesByName("XDICT");


  14:      s += myProcesses[0].TotalProcessorTime.ToString()+"\n";


  15:      s += myProcesses[0].UserProcessorTime.ToString()+"\n";


  16:      s += myProcesses[0].PrivilegedProcessorTime.ToString()+"\n";


  17:      s += myProcesses[0].StartTime.ToString();


  18:      MessageBox.Show(s,"");


  19:      MessageBox(myProcesses.GetValue().ToString());


  20:      foreach (System.Diagnostics.Process instance in myProcesses)


  21:      {


  22:          instance.WaitForExit(3000);


  23:          instance.CloseMainWindow();


  24:      }


  25:   


  26:  }

主要就是用C#准备好的Process类,其中有一个方法是Start,传入进程名,就可以启动某进程,如启动word,就可以使用第三行那样的方式。这样的话,就可以做一个按钮来触发某个程序的运行,用StartTime来获取启动的时间,并且每一秒钟获取一次进程的CPU占用(用TotalProcessorTime这个属性),用TotalProcessorTime/1s,这样就算是CPU占用率/1s,可能会不精确,但是暂时还没有想到更精确的方式,然后做一个统计,累加时间,直到CPU占用率降到零的时候,停止计时,这样得到的时间就是程序的大致启动时间,在理想的状态下,总比用秒表计时准确吧,公司的某产品用秒表计时还记得过来,可是word 2003一闪而过啊。如果要精确些还可以用比1s更小的单位,精确程度,我想就是执行Start和得到StartTime之间有指令延时,以及得到CPU总时间和除法花去的时间,这都是造成误差的时间,但是我想现在CPU速度这么快,总比人用手计时快,有什么更好的方法,还要继续研究。C#确实,有.net framework给它撑腰,很多事情都不用程序员做了,难以想象c++实现这个的难度,不过,如果能直接得到cpu占用率,岂不更妙?
这个程序稍微完善一下就可以交工了

Published At
Categories with Web编程
Tagged with
comments powered by Disqus