APT技术(1)

一. 代码编写

我们的代码分成两个module,module1用于定义注解和注解的解析,并注册注解的解析类(Processor),module2依赖module1,来真正的使用module1中定义好的注解来完成特定的功能。

gradle版本必需使用4.8。

代码参考:GitHub - JohnZhaowen/rpt-processor

1. 注解处理器:

@SupportedAnnotationTypes("com.john.annotation.MyAnno")
@SupportedSourceVersion(SourceVersion.RELEASE_8)
public class MyAnnoProcessor extends AbstractProcessor {

    @Override
    public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
        System.out.println("#################$$$$$$$$$$$$$$$");
        return false;
    }

}

2. 注解处理器注册

在resources目录下创建目录META-INF/services,在该目录下创建文件javax.annotation.processing.Processor,并将需要处理的处理器配置在该文件中:

com.john.annotation.proc.MyAnnoProcessor

二.代码运行

注解处理器注册好之后,编译代码时,就会运行注解处理器。

 运行build命令后,对应的日志如下:

> Task :my-anno:compileJava
> Task :my-anno:processResources
> Task :my-anno:classes
> Task :my-anno:jar

> Task :my-service:compileJava
#################$$$$$$$$$$$$$$$
#################$$$$$$$$$$$$$$$

> Task :my-service:processResources NO-SOURCE
> Task :my-service:classes
> Task :my-service:jar
> Task :my-service:assemble
> Task :my-service:compileTestJava NO-SOURCE
> Task :my-service:processTestResources NO-SOURCE
> Task :my-service:testClasses UP-TO-DATE
> Task :my-service:test NO-SOURCE
> Task :my-service:check UP-TO-DATE
> Task :my-service:build

三.Debug

在注解处理器代码中打好断点,然后以debug方式运行build命令

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值