文章目录
- 一、注解处理器 AbstractProcessor
- 二、使用注解 @AutoService(Processor.class) 标注 注解处理器
- 三、注解处理器 init 初始化方法
- 四、注解处理器 Filer 代码生成工具
- 五、注解处理器 Messager 日志打印工具
- 六、博客资源
一、注解处理器 AbstractProcessor
上一篇博客 【Android APT】编译时技术 ( 开发编译时注解 ) 中 开发 了 annotation 编译时注解 依赖库 , 很简单 , 只有一个 BindView 注解 ;
本博客开始进行开发 注解处理器 依赖库 ;
在 【Android APT】编译时技术 ( 编译时注解 和 注解处理器 依赖库 ) 博客中创建了 annotation-compiler 注解处理器 依赖库 , 基于该基础开发 注解处理器 ;
创建 Compiler 注解处理器 , 该类主要作用是生成代码 , 注解处理器类必须继承 javax.annotation.processing.AbstractProcessor 类 , 这是 Java 的 API , 再 Android 中无法获取该 API , 因此 编译时注解 和 注解处理器 都必须是 Java 依赖库 ;
代码语言:javascript复制package kim.hsl.annotation_compiler;
import java.util.Set;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.RoundEnvironment;
import javax.lang.model.element.TypeElement;
/**
* 生成代码的注解处理器
*/
public class Compiler extends AbstractProcessor {
@Override
public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
return false;
}
}
二、使用注解 @AutoService(Processor.class) 标注 注解处理器
上述实现的 AbstractProcessor 中的 process 方法 , 专门用于搜索 Android 源码中使用的 编译时注解 的方法 ;
程序构建时 , 发现了 annotationProcessor project(path: ':annotation-compiler')
依赖 , 使用 annotationProcessor 进行依赖 , 说明这是一个注解处理器 , 此时会到 annotation-compiler 模块中查找 注解处理器 , 注解处理器 的查找方式也是 通过 注解 标记 进行查找 , 该注解是 Google 服务库提供的 ;
如果要使用 注解 标记注解处理器 , 首先要依赖 Google 服务库 ,
代码语言:javascript复制dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
annotationProcessor 'com.google.auto.service:auto-service:1.0-rc4'
compileOnly 'com.google.auto.service:auto-service:1.0-rc3'
}
然后到 public class Compiler extends AbstractProcessor
注解处理器类上使用 @AutoService(Processor.class)
标注 , Android 编译器通过查找该注解 , 确定哪个类是注解处理器 ;
import com.google.auto.service.AutoService;
import java.util.Set;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.Processor;
import javax.annotation.processing.RoundEnvironment;
import javax.lang.model.element.TypeElement;
/**
* 生成代码的注解处理器
*/
@AutoService(Processor.class)
public class Compiler extends AbstractProcessor {
@Override
public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
return false;
}
}
三、注解处理器 init 初始化方法
AbstractProcessor 注解处理器中 , 专门提供了一个 init 方法 , 该方法专门用于注解处理器相关初始化操作 ;
代码语言:javascript复制@Override
public synchronized void init(ProcessingEnvironment processingEnv) {
super.init(processingEnv);
}
init
方法的 ProcessingEnvironment processingEnv 参数很重要 , 通过该参数可以获取 注解处理器中的各种重要工具 ;
ProcessingEnvironment
中定义了获取相关工具的接口 ;
public interface ProcessingEnvironment {
Map<String,String> getOptions();
Messager getMessager();
Filer getFiler();
Elements getElementUtils();
Types getTypeUtils();
SourceVersion getSourceVersion();
Locale getLocale();
}
四、注解处理器 Filer 代码生成工具
通过注解生成 Java 代码需要使用 Filer
对象 , 将该对象定义到 注解处理器 成员变量中 , 在 init
方法中进行初始化操作 ;
通过 ProcessingEnvironment
可以通过调用 getFiler
方法 , 获取 Filer
对象 ;
/**
* 生成 Java 代码对象
*/
private Filer mFiler;
/**
* 初始化注解处理器相关工作
* @param processingEnv
*/
@Override
public synchronized void init(ProcessingEnvironment processingEnv) {
super.init(processingEnv);
this.mFiler = processingEnv.getFiler();
}
五、注解处理器 Messager 日志打印工具
注解处理器中不能打断点进行调试 , 也不能使用 Log , System.out 打印日志 , 在注解处理器中只能通过 Messager
打印日志 ;
通过调用 ProcessingEnvironment
的 getMessager
方法 , 可以获取到 Messager
对象 ;
/**
* 日志打印
*/
private Messager mMessager;
/**
* 初始化注解处理器相关工作
* @param processingEnv
*/
@Override
public synchronized void init(ProcessingEnvironment processingEnv) {
super.init(processingEnv);
this.mMessager = processingEnv.getMessager();
}
六、博客资源
博客源码 :
- GitHub : https://github.com/han1202012/APT