我正在尝试从源代码中分析一个名为Nutch的Java web搜索程序。据我所知,要分析,我需要在编译器中启用分析,以便生成要在GProf等程序中打开的分析文件。如果我编译软件所做的一切都是在源码根目录下运行ANT,我该怎么做?
发布于 2010-11-06 14:18:40
如果您运行的是较新的JDK (最新的1.6更新7或更高版本),则不需要做任何准备Java进程进行性能分析的工作。只需使用JVisualVM (它随JDK提供)附加到您的流程,然后单击profile按钮。
发布于 2010-11-08 01:26:43
你在回应@Charlie的回答时说,理想情况下,你想知道关于的信息,程序是如何花费时间的。
还有另一种观点--你需要知道为什么程序要花费时间。
花费每个周期的原因是一系列原因,其中每个链接都是调用堆栈上的一行代码。这条链条并不比它最薄弱的一环强多少。
除非程序尽可能快,否则你就会遇到“瓶颈”。
例如,如果“瓶颈”浪费了20%的时间,那么它由可优化的代码行组成(即不合理),20%的时间在堆栈上。你要做的就是找到它。
如果从堆栈中抽取10,000个样本,那么将会有大约2,000个样本。如果抽取10个样本,平均会有2个样本。
实际上,如果您随机暂停程序几次并研究调用堆栈,如果您在少至2示例上看到一行可优化的代码,那么您就发现了一个“瓶颈”。你可以修复它,获得一个很好的加速,然后重复整个过程。
这是this technique的基础。
无论如何,从 concepts的角度思考并不能很好地服务于您。
发布于 2010-11-06 14:07:32
你真的是在问一个Ant问题。您可以将编译器的命令行标志作为属性添加到编译目标的ant文件中。请参阅<compilerarg> tag here。
顺便说一句,有很多很好的分析工具。看看this google search吧。
https://stackoverflow.com/questions/4112131
复制相似问题