Kotlin注解处理器

说干就干。首先得在里配置kapt。刚开始傻乎乎地直接加了插件,结果同步一直失败。后来才发现得先在块里声明:

然后在dependencies里引入注解处理器,比如用AutoService:

这里踩过坑:忘记加implementation依赖会导致编译报错提示找不到注解类。

定义注解倒是不难。写了个注解:

重点在于------编译完注解就没用了,毕竟我们只需要在源码阶段处理它。

重头戏是写处理器。继承自后,先重写方法:

刚开始用Java的写法,后来发现Kotlin要用才准确。

最核心的方法里,得先遍历所有带注解的元素:

这里被类型转换坑过------明明判断了是CLASS,转换成TypeElement时还是可能抛出异常,最好用安全转换。

代码生成部分用了,虽然项目是Kotlin但生成Java代码更稳妥。后来发现用还能直接生成kt文件,不过得处理更多兼容性问题。以生成方法为例:

字符串拼接那里特别容易出错,换行符和引号转义需要特别小心。有次因为少了个转义斜杠,生成出来的代码直接编译报错。

调试也是个技术活。最开始用语句死活看不到输出,后来学会用在编译时查看日志。还有个技巧是在里手动创建文件,列出处理器全限定名,不然编译器可能找不到自定义处理器。

最后在数据类上加上注解,编译时就会自动生成对应的辅助类。虽然第一次配置花了整整两天,但看到编译后自动生成的代码,那种成就感简直了。现在团队里新增类似功能都直接套用这个模式,开发效率提升明显。

不过要提醒的是,注解处理器会延长编译时间,在持续集成环境可能需要额外分配内存。建议把生成的代码单独放在build目录,避免污染源码。另外现在有KSP(Kotlin Symbol Processing)这个新方案,据说比kapt更高效,下次项目升级可以考虑迁移。

相关推荐
雨中飘荡的记忆5 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑13 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_14 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero17 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记17 小时前
Spring Boot条件注解详解
java·spring boot
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林5512 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
A0微声z2 天前
Kotlin Multiplatform (KMP) 中使用 Protobuf
kotlin
华仔啊2 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing2 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员