- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我是分析方面的新手。我想优化我的代码以满足时间限制。我使用 Visual C++ 08 Express,因此不得不下载一个分析器,对我来说它非常困。我做了一些搜索,但没有找到关于 Sleepy 的体面教程,这里是我的问题:如何正确使用?我掌握了profiling的大概思路,所以我按照%exclusive排序,找出我的瓶颈。首先,在这个列表的顶部,我有 ZwWaitForSingleObject、RtlEnterCriticalSection、operator new、RtlLeaveCriticalSection、 printf,一些迭代器……在它们占用大约 60% 之后出现了我的第一个函数,子调用的第一个位置。有人可以解释为什么上面提到的出来,它们是什么意思,如果我无法访问这个关键的 60%,我该如何优化我的代码? (对于“源文件”:未知...)。另外,对于我的功能,我认为我为每一行都有时间,但事实并非如此,例如算术或某些函数没有时间(不嵌套在未使用的“if”子句中)。最后一件事:如何找出某行可以超快执行,但被调用数千次,成为真正的瓶颈?
最后,Sleepy 好不好?或者我的平台有一些免费的替代品?
帮助非常感谢!干杯!
我找到了另一个版本的分析器,称为 plain Sleepy。它显示了某个片段被调用的次数加上行数(我猜它指向关键的那一行)。所以在我的例子中.. KiFastSystemCallRet 占用 50%!这意味着它等待一些数据对吗?如何改进这个问题,是否有一种合适的方法来追踪导致这些多次调用的原因并最终删除/更改它?
最佳答案
I'd like to optimize my code to satisfy timing constraints
您遇到了这项业务中的一个长期存在的问题。您想要找到使代码花费更少时间的方法,并且您(和许多人)认为(并且已被教导)做到这一点的唯一方法是进行各种测量。
有小众观点,唯一值得推荐的是actual significant results (plus an ironclad theory behind it)。
如果您有一个“瓶颈”(您有,可能有几个),它会花费一些时间,例如 30%。
就把它当作一个待发现的 bug。
使用暂停按钮随机停止程序,仔细查看程序正在做什么以及为什么这样做。询问它是否可以摆脱。这样做 10 次。平均而言,您会在 3 次暂停时看到问题。任何你不止一次看到的事件,如果不是真正必要的话,都是速度错误。这不会准确地告诉您问题的成本是多少,但它确实会准确地告诉您问题是什么,以及它是否值得修复。你会以这种方式看到任何分析器都无法找到的东西,因为分析器只是程序而已,不能宽泛的看待什么是机会。
有些人规避风险,认为它可能无法提供足够的加速,不值得。诚然,获得低返回的可能性很小,但这就像投资一样。该理论表明,平均来说这是值得的,而且获得高返回的可能性也很小。无论如何,如果您担心风险,多一些样本将消除您的恐惧。
解决问题后,其余瓶颈各占较大百分比,因为它们并没有变小,但整个程序变小了。因此,当您重复整个过程时,它们会更容易找到。
有很多关于性能分析的文献,但很少有人真正说明它在实践中实现了多少加速。 Here's a concrete example几乎有 3 个数量级的加速。
关于c++ - C++ 代码的探查器,非常困,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13641484/
更新:随意给我反对票,因为问题是我将文件命名为 _stylesheet.html.erb 而不是 _stylesheets.html.erb。我以为我检查了拼写,但显然我没有。我很抱歉浪费了大家的时间
我有一个 Inno Script istaller 在其中运行子 setup.exe 。当向主安装程序提供静默安装参数时,我必须向 setup.exe 提供静默安装参数。 Inno脚本运行命令: [R
我正在尝试在大型数据库中搜索长的、近似的子字符串。例如,一个查询可能是一个 1000 个字符的子字符串,它可能与匹配项相差数百个编辑的 Levenshtein 距离。我听说索引 q-gram 可以做到
我正在尝试在我的应用程序中实现一个非常简单的绘图 View 。这只是我的应用程序的一小部分,但它正在变成一个真正的麻烦。这是我到目前为止所拥有的,但它现在显示的只是莫尔斯电码,如点和线。 - (v
我有一个运行非常慢的 sql 查询,我很困惑为什么。查询是: SELECT DISTINCT(c.ID),c.* FROM `content` c LEFT JOIN `content_meta`
我搜索过这个,但我发现的所有结果对我来说都毫无意义,而且似乎太复杂了。我希望使用 json 或 simplejson 模块来获取对象中字符串的值。 string = '{"name": "Alex"}
我想编写一个流量生成器来复制正在运行的计算机对内存进行的原始读写需求。 但是正在运行的计算机在其内存引用中也显示出(非常强的)局部性,并且在 64 位地址空间中,只会引用非常小范围的地址(事实上,我已
我正在尝试做一个 Project Euler问题,但它涉及添加一个非常大的数字的数字。 (100!) 用Java的int和long太小了。 谢谢你的建议 最佳答案 类 BigInteger看起来它可能
我想在游戏中实现一个物理引擎,以便计算物体在受力时的轨迹。该引擎将根据对象的先前状态计算对象的每个状态。当然,这意味着要在两个时间单位之间进行大量计算才能足够精确。 为了正确地做到这一点,我首先想知道
Edit3:通过将数组的初始化限制为仅奇数进行优化。谢谢@Ronnie! Edit2:谢谢大家,看来我也无能为力了。 编辑:我知道 Python 和 Haskell 是用其他语言实现的,并且或多或少地
背景 我有一个我编写的简单媒体客户端/服务器,我想生成一个非显而易见的时间值,我随每个命令从客户端发送到服务器。时间戳将包含相当多的数据(纳秒分辨率,即使由于现代操作系统中定时器采样的限制,它并不真正
一位招聘软件工程师的 friend 希望我为他开发一个应用。 他希望能够根据技能搜索候选人的简历。 正如您想象的那样,可能有数百、可能数千种技能。 在表格中表示候选人的最佳方式是什么?我在想 skil
我的意思是“慢”,回调类型等待远程服务器超时以有效触发(调用 vimeo 提要,解析它,然后在场景中显示 uiviews) 我大多不明白它是如何工作的。我希望在返回响应后立即从回调中填充我的 View
您好,我正在研究使用快速可靠的生产者消费者队列进行线程切换。我正在使用 VC++ 在 Windows 上工作。 我的设计基于 Anthony Williams队列,基本上就是一个带有 boost::c
我只是想知道您使用 resharper 的经验。我们有一个非常重的 dbml 文件,因为我们的数据库有很多表,每次我需要打开该文件时,我都会收到来自 resharper 的大量异常。以前有人遇到过这个
我目前正在使用 jQuery 中的隐藏/显示功能来帮助从选择框中将表格过滤成组。 实际代码运行良好,但速度非常慢,有时需要一两分钟才能执行。 我切换了代码,所以它使用 css({'display':'
我按顺序调用了以下两个方法(按顺序使用适当的类级别字段) public const string ProcessName = "This is" public const string WindowT
我很难理解描述反射包的文档/示例。我是一名命令式编程老手,但也是一名 Haskell 新手。你能引导我完成一个非常简单的介绍吗? 包裹:https://hackage.haskell.org/pack
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我正在尝试编写一段代码来操作一个很长的文档(超过一百万行)。在这个文本文件中,有固定间隔(每 1003 行)和之间的某些时间戳有我需要的数据,它有 1000 行长,还有一个标题和两个空行,但我不需要。
我是一名优秀的程序员,十分优秀!