ant评测Java代码
我试图从源代码中分析一个名为Nutch的Java web搜索程序。据我所知,要进行概要分析,我需要在编译器中启用概要分析,以便生成要在GProf之类的程序中打开的概要文件。如果我编译软件所做的一切都是在源根目录下运行ANT,我该怎么做
你可以在下面搜索框中键入要查询的问题!
我试图从源代码中分析一个名为Nutch的Java web搜索程序。据我所知,要进行概要分析,我需要在编译器中启用概要分析,以便生成要在GProf之类的程序中打开的概要文件。如果我编译软件所做的一切都是在源根目录下运行ANT,我该怎么做
# 1 楼答案
你真的在问一个蚂蚁问题。您可以将编译器的命令行标志作为属性添加到编译目标的ant文件中。请参阅
<compilerarg>
标记here顺便说一下,有很多很好的分析工具。看看this google search
# 2 楼答案
如果您运行的是较新的JDK(最新的1.6更新版本7或更高版本),那么您不需要做任何事情来准备您的Java进程进行概要分析。只需使用JVisualVM(JDK附带)来附加到流程,然后单击profile按钮
# 3 楼答案
您在回答@Charlie的回答时说,理想情况下,您希望了解有关程序如何花费时间的信息
还有另一种观点-你需要知道程序花费时间的原因
每个周期花费的原因是一系列原因,其中每个链接都是调用堆栈上的一行代码。这条链条最薄弱的一环也不牢固
除非程序尽可能快,否则就会出现“瓶颈”
例如,如果一个“瓶颈”浪费了20%的时间,那么它由一行可优化的代码组成(即,不合理的代码),这行代码占堆栈时间的20%。你所要做的就是找到它
如果采集10000个烟囱样本,大约需要2000个。如果采集10个样本,则平均为其中2个样本
事实上,如果您随机暂停程序几次并研究调用堆栈,如果您在2个样本上看到一行可优化的代码,您就会发现一个“瓶颈”。 您可以修复它,获得良好的加速,并重复整个过程
这是this technique的基础
无论如何,从gprof concepts的角度思考并不能很好地为您服务