首先看一下这个常量类,数据库有多少个表,就有多少个常量字段。如果有100个,1000个,10000个,那是不是要写这么多了,这种搞法太愚蠢。那有没有聪明点的搞法了,那就是使用AbstractProcessor在编译期间自动生成类。代码已经实现:
在编译的时候,自动产生了BoPurchaseMainTableConstants,项目里直接使用就可以了自动产生了BoPurchaseMainTableConstants 的时候,需要查询数据库,拼接字段。就可以把所有的表都是产生一个常量字段了,至于变量名,按照约定取就可以了。这个类不需要提交到git仓库,只要编译就会自动产生。
AbstractProcessor可以实现编译期间的事项,如代码检查等等。
按照处理时期,注解分为两种类型,一种是运行时注解,另一种是编译时注解。
编译时注解的核心依赖APT(Annotation Processing Tools)实现,对应的处理流程为:
在某些代码元素上(如类型、函数、字段等)添加注解;
编译时编译器会检查AbstractProcessor的子类,
然后将添加了注解的所有元素都传递到该类的process函数中;
使得开发人员可以在编译器进行相应的处理。
例如,根据注解生成新的Java类,
这也就是EventBus,Retrofit,Dragger等开源库的基本原理。