我將 JavaParser 用于代碼分析項目,我在其中讀取 Java 源文件并生成 AST(抽象語法樹)進(jìn)行分析。我需要確定來自 AST 的給定塊語句所跨越的原始行數(shù)?;旧衔矣幸粋€這樣的方法:int numberOfLines(Node astNode){....}我需要返回跨越的行數(shù)。例子:void something(){// hello world}會返回 5。我嘗試轉(zhuǎn)換為字符串并計算行數(shù),如下所示:new BufferedReader(new StringReader(nodeHere.toString())).lines().count() ,但由于缺乏詞法保留,這不起作用......例如,單行如下:“class TestClass {int x; int y; int zz (int a){return a;} }" 變成 10 行:class TestClass { int x; int y; int zz(int a) { return a; }}當(dāng)生成 AST 時,然后將其轉(zhuǎn)換回字符串,本質(zhì)上是“美化”它……但是,JavaParser 確實(shí)保留了范圍屬性中的原始“坐標(biāo)”,所以也許可以以某種方式使用它?
2 回答

眼眸繁星
TA貢獻(xiàn)1873條經(jīng)驗(yàn) 獲得超9個贊
有范圍和tokenRange,您可以使用性能。即類似的東西range.end.line - range.begin.line

aluckdog
TA貢獻(xiàn)1847條經(jīng)驗(yàn) 獲得超7個贊
這個答案可能很晚了,但這對我有用......
public void visit(MethodDeclaration method) {
int methodBodyLength = method.getRange().map(range -> range.begin.line - range.end.line).orElse(0);
}