javaParser+JavaParserSymbolSolver version:3.24.10 简单使用

文章介绍了如何使用JavaParser库进行Java源代码的解析,包括parse方法读取文件,打印AST树,以及使用YamlPrinter打印格式化后的代码。此外,还提及了symbolSolver在解决方法调用和类型解析中的应用,强调了查阅官方文档的重要性。
摘要由CSDN通过智能技术生成

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


一、Usage

1.parse

  public static String path="src/main/java/test.java";
  //  public static String Srcpath="src/main/java";




JavaParser parser = new JavaParser();
        ParseResult<CompilationUnit> cu=null;
        try {

			 cu = parser.parse(new File(path));//---------------WATCH OUT HERE------------

        } catch (FileNotFoundException e) {
            throw new RuntimeException(e);
        }

2.print

 cu.getResult().ifPresent(YamlPrinter::print);

for example

from:

class test{

    int ttt=0;
    int ddd;

    public test() {
        ddd=1;
    }

    public static void main(String[] args) {
       add(2);
    }


    static int add(int x) {

        return 0;
    }

}

to:

root(Type=CompilationUnit):
types:
- type(Type=ClassOrInterfaceDeclaration):
isInterface: “false”
name(Type=SimpleName):
identifier: “test”
members:
- member(Type=FieldDeclaration):
variables:
- variable(Type=VariableDeclarator):
initializer(Type=IntegerLiteralExpr):
value: “0”
name(Type=SimpleName):
identifier: “ttt”
type(Type=PrimitiveType):
type: “INT”
- member(Type=FieldDeclaration):
variables:
- variable(Type=VariableDeclarator):
name(Type=SimpleName):
identifier: “ddd”
type(Type=PrimitiveType):
type: “INT”
- member(Type=ConstructorDeclaration):
body(Type=BlockStmt):
statements:
- statement(Type=ExpressionStmt):
expression(Type=AssignExpr):
operator: “ASSIGN”
target(Type=NameExpr):
name(Type=SimpleName):
identifier: “ddd”
value(Type=IntegerLiteralExpr):
value: “1”
name(Type=SimpleName):
identifier: “test”
modifiers:
- modifier(Type=Modifier):
keyword: “PUBLIC”
- member(Type=MethodDeclaration):
body(Type=BlockStmt):
statements:
- statement(Type=ExpressionStmt):
expression(Type=MethodCallExpr):
name(Type=SimpleName):
identifier: “add”
arguments:
- argument(Type=IntegerLiteralExpr):
value: “2”
type(Type=VoidType):
name(Type=SimpleName):
identifier: “main”
modifiers:
- modifier(Type=Modifier):
keyword: “PUBLIC”
- modifier(Type=Modifier):
keyword: “STATIC”
parameters:
- parameter(Type=Parameter):
isVarArgs: “false”
name(Type=SimpleName):
identifier: “args”
type(Type=ArrayType):
origin: “TYPE”
componentType(Type=ClassOrInterfaceType):
name(Type=SimpleName):
identifier: “String”
- member(Type=MethodDeclaration):
body(Type=BlockStmt):
statements:
- statement(Type=ReturnStmt):
expression(Type=IntegerLiteralExpr):
value: “0”
type(Type=PrimitiveType):
type: “INT”
name(Type=SimpleName):
identifier: “add”
modifiers:
- modifier(Type=Modifier):
keyword: “STATIC”
parameters:
- parameter(Type=Parameter):
isVarArgs: “false”
name(Type=SimpleName):
identifier: “x”
type(Type=PrimitiveType):
type: “INT”

4.symbolSolver

the content on web or official book are too old
here is what i found through trial

class visitor extends VoidVisitorAdapter<Void> {

    CombinedTypeSolver solver = new CombinedTypeSolver();

    public visitor() {
        super();

        solver.add(new JavaParserTypeSolver(Main.Srcpath) );


    }


    @Override
    public void visit(MethodDeclaration md, Void arg) {super.visit(md,arg);
    //do what you like here

          System.out.println(md.getName());
          System.out.println(md.getBody());
          System.out.println(md.getType());
          System.out.println(md.getDeclarationAsString());
       	  System.out.println(md.get)

    }

    @Override
    public void visit(MethodCallExpr n, Void arg) {

//do what you like here

      //  ResolvedType type= JavaParserFacade.get(solver).getType(n);
     //   MethodUsage tsype = JavaParserFacade.get(solver).solveMethodAsUsage(n);
       // System.out.println(type);
//        System.out.println(tsype.getCorrespondingDeclaration());
//        System.out.println(tsype.getDeclaration());
       // System.out.println(tsype.getClass());

    //    System.out.println(tsype.getQualifiedSignature());

        super.visit(n, arg);
    }
}

use it :

   		visitor visitor=new visitor();
        visitor.visit(cu.getResult().get(), null);
java精神(基于函数式组合子逻辑的javaparser框架) 一。 释名。 为什么叫精神? 如果你熟悉c++,那么你可能知道一个叫做”spirit”的parser库。它利用c++的模板元编程能力,使用c++语言本身提供了一个递归下降文法解析的框架。 我这里介绍的jparsec库,就是一个java里面的递归下降文法解析框架。 不过,它并非是spirit的java版本。 Jparsec的蓝本来自Haskell语言的parsec库。Parsec是一个基于monad的parser组合子库。 这个库的目的是要在java中提供一个类似parsec, spirit的库,这种组合子库并非c++的专利,java/c#也可以做到。这个库还将在java5.0上被改写,类型安全上它将也不再逊色于c++。 那么,为什么叫“函数式”呢?java是面向对象的嘛。 如果你使用过haskell, lisp等语言,这个函数式不用解释你也知道是怎么回事了。 如果你是一个老牌的c++/java程序员,那么这里还要稍微解释一下。当然如果您对这些虚头八脑的名词不感兴趣,那么,你尽可以跳过这一章,不知道什么是“函数式”,并不会影响你对这个库的理解的。 C++这几年随着gp的普及,“函数式”这个老孔乙己逐渐又被人从角落里面拽了出来。一个c++程序员所熟悉的“函数式”很可能是stl的for_each, transform,count_if这些函数。 怎么说呢,就象我不能否定str.length()这个调用属于OO一样,我也无法说for_each, transform不是函数式。 但是,“函数式”的精髓不在于此。 一般归纳起来,就像我们说OO是什么多态,封装,继承一样,“函数式”的特征被总结为: 1。无副作用。 2。高阶函数。 3。延迟计算 而最最有意义的(至少我认为如此),是基于高阶函数的函数组合能力。一些人把这叫做glue。 简短地说,什么让函数式编程如此强大?是用简单的函数组合出复杂函数的能力。 我可以想象,说到这里,你还是一头雾水。“什么是组合?1+1不是也把两个1组合成2了吗?new A(new B(), new C())不也是从B和C组合成A了?”
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值