我对WALA很新,并试图通过一些简单的例子来感受它。我正在尝试为下面非常简单的类构建一个调用图
public class Example {
public static void main(String[] args) {
int x = 1;
int y = 1;
int z = x + y;
Math.pow(x, y); // issue here
}
}
我的WALA代码(有些简化)是:
import com.ibm.wala.ipa.callgraph.*;
import com.ibm.wala.ipa.callgraph.impl.Util;
import com.ibm.wala.ipa.cha.ClassHierarchy;
import com.ibm.wala.util.WalaException;
import com.ibm.wala.util.config.AnalysisScopeReader;
...
AnalysisScope scope = AnalysisScopeReader.makeJavaBinaryAnalysisScope(jar, null);
ClassHierarchy cha = ClassHierarchy.make(scope);
Iterable<Entrypoint> entryPoints = Util.makeMainEntrypoints(scope, cha);
AnalysisOptions opts = new AnalysisOptions(scope, entryPoints);
AnalysisCache cache = new AnalysisCache();
CallGraphBuilder cgBuilder = Util.makeZeroCFABuilder(opts, cache, cha, scope);
CallGraph cg = cgBuilder.makeCallGraph(opts, null);
当示例没有调用main中的其他方法时,它工作正常,但只是挂起(卡住cgBuilder.makeCallGraph
)。
非常感谢任何建议。
答案 0 :(得分:4)
以下是一些可能有助于提高运行速度的选项
1)考虑从分析选项中删除reflectionOptions。这对于更复杂的代码来说并不是很好,但对于基本示例,它可能会有所帮助 你可以通过
这样做options.setReflectionOptions(ReflectionOptions.NONE);
2)尝试使用不同的构建器 例如
ZeroXCFABuilder.make(cha, options, cache, null, null,
ZeroXInstanceKeys.ALLOCATIONS | ZeroXInstanceKeys.CONSTANT_SPECIFIC);
还有更多选项,请检查ZeroXInstanceKeys
以了解您可能愿意使用哪些选项。
3)最后,这可能会给你一个很好的运行时间,添加排除
String exclusionFile = p.getProperty("exclusions");
AnalysisScope scope = AnalysisScopeReader.makeJavaBinaryAnalysisScope(appJar, exclusionFile != null ? new File(exclusionFile)
请注意以下排除文件的正则结构
java\/awt\/.*
javax\/swing\/.*
sun\/awt\/.*
sun\/swing\/.*
com\/sun\/.*
sun\/.*
没有空格,每行一次输入等 这应该有帮助