在开发.NET应用程序中,尤其是数据库+运算密集的混合应用时,时常发现应用程序运行的不够快,优化无疑是一个程序员不得不面临的问题。如何找到软件系统的瓶颈就成了摆在程序员面前的难题。微软的Application Center Test 能够帮助ASP.NET程序员随时回答性能到底恶化到哪里了,但是要找出到底应用程序的那一部分导致了运行缓慢ACT却无能为力。对于桌面型的exe应用程序,ACT就更不行了,当然有很多商业的剖析器可以回答上述问题(大多数都很贵),但最近开发的开放源代码的nprof却是最可行的方案。
nprof下载地址为:http://nprof.sourceforge.net/
在文章中使用nprof 0.9alpha版的bin分发运行包nprof-0.9b-alpha.zip进行讲解,更新版本应该类似。
nprof解压缩后,双击RegisterProfilerHook.bat注册剖析Hook,反注册请手工执行:regsvr32 /u bin/nprof.hook.dll
完成上述操作后即可运行NProf.Application.exe。通过File->New菜单命令创建一个新的剖析器项目,选择一个要分析的exe执行程序,然后创建项目即可。对话框中Common Options的两个选项对于File项目类型都不用选。确认后按F5即可运行欲分析的exe,执行一些此exe的操作,退出后即可看到nprof详细的剖析这次操作的数据。提醒一句,当exe程序被剖析时,文档显示运行速度将会比平时慢20倍左右,因为CLR的profiling API需要记录几乎没一个调用的时间等等信息。
最后解释一下剖析的结果意义来结束本文:当你选择任意的被方法名后,nprof还会在列表下方显示被选择方法的Calless(调用其它方法)和Callers(被其它方法调用)的一些信息,其中:
你也可以单击列表列表头,这将对此列排序,这样更容易找到瓶颈,找到瓶颈后,就可以开始有目标的考虑如何优化应用程序了。最后提醒一句,只要应用程序足够快就可以了,毕竟客户很少会为快一倍的应用程序多付一倍的钱,而要让应用程序快一倍所付出的努力却往往不只一倍。