博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用Performance Analysis提高代码效率----By Yishi
阅读量:5299 次
发布时间:2019-06-14

本文共 760 字,大约阅读时间需要 2 分钟。

 

做ASE课上的个人项目时,老师推荐我们用Visual Studio的ANALYZE功能去查找使代码效率变低的部分并改正。下面简单叙述一下使用该功能的步骤。

像我这样非CS专业的人写代码的时候往往只会以实现功能为导向,写的时候不会特别注意代码效率的问题。就比如说下面举的这个例子,是一个批量处理txt文件并提取出其中长度大于1的英文单词并统计频率的程序。我刚开始写的时候,就是想要一个一个遍历文件中的字符,将两个分隔符之间的字符串看作是一个单词,并加入单词树中。写完以后,我认为程序的大部分运行时间应该是花在将单词加入树中的这一过程,因为要对单词的每个字母作比较。于是我想用ANALYZE验证一下,使用很简单,VS菜单栏上点开ANALYZE,然后点start performance analysis, 一般都是使用采样方法,所以就不需要更多的设置了,结果如下图:

ANALYZE的结果有多重视图显示,上面这种看起来不是很方便,可以点Current View右边的下拉菜单,选择Function Details视图,就能很方便的看到程序中占运行时间较大的部分了,VS甚至能比较精确地定位到这些程序段的位置,如下图:

于是我发现逐个字符的扫描txt文件要重复的使用fscanf函数,这个函数运行起来非常耗时,所以我考虑一次性将文件内所有字符读入一个字符串中,然后直接对字符串操作,而不是每次都用fscanf这种操作文件的函数。改完以后再使用ANALYZE验证,得到如下结果:

如我之前所想的,程序的把部分时间花在将单词加入单词树的AddRecord函数上,说明上面的改动是很正确的。

转载于:https://www.cnblogs.com/bigbadwolf/archive/2012/09/24/2699438.html

你可能感兴趣的文章
apache简介与安装
查看>>
从头开始写框架(二):孕育框架的种子_下
查看>>
华为手机在开发Android调试时logcat不显示输出信息的解决办法
查看>>
TCP 建立连接为什么要握 3 次手?
查看>>
android:ToolBar详解
查看>>
window.print 打印指定 div
查看>>
拼多多2018/8/5算法工程师笔试
查看>>
【LINUX】——FreeBSD中的一些常规配置
查看>>
GreenDao3.0新特性解析(配置、注解、加密)
查看>>
JSON数组分配输出每个li
查看>>
request属性 request.getAttribute()
查看>>
Android应用开发基础篇(16)-----ScaleGestureDetector(缩放手势检测)
查看>>
iOS状态栏变文字颜色改变
查看>>
Entity framework code first
查看>>
Vue中登录模块
查看>>
正则表达式1--特殊字符
查看>>
python基础(四)
查看>>
2018 ACM南京网络赛H题Set解题报告
查看>>
深入理解JS立即执行函数
查看>>
python基础知识学习:列表和元组
查看>>