V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
warcraft1236
V2EX  ›  Java

kotlin 有没有类似 lombok 那样的 @slf4j 注解

  •  
  •   warcraft1236 · 2021-06-28 10:10:23 +08:00 · 2273 次点击
    这是一个创建于 1250 天前的主题,其中的信息可能已经有所发展或是发生改变。
    不想每个文件都手动写 logfactory
    6 条回复    2022-07-08 11:50:49 +08:00
    ipeony
        1
    ipeony  
       2021-06-28 10:34:25 +08:00
    目前在用这个库,比手写稍微方便一点
    https://github.com/MicroUtils/kotlin-logging
    yumerdev93
        2
    yumerdev93  
       2021-06-28 10:48:30 +08:00
    早上刚抄的
    yumerdev93
        3
    yumerdev93  
       2021-06-28 10:48:40 +08:00
    @Retention(AnnotationRetention.RUNTIME)
    @Target(AnnotationTarget.CLASS)
    annotation class Slf4j {
    companion object{
    val <reified T> T.log:Logger
    inline get() = LoggerFactory.getLogger(T::class.java)
    }
    }
    MarkLeeyun
        4
    MarkLeeyun  
       2021-06-28 14:39:59 +08:00
    没有。
    hdfg159
        5
    hdfg159  
       2021-06-30 08:08:40 +08:00 via Android
    哈哈哈,没有,groovy 有
    bitmin
        6
    bitmin  
       2022-07-08 11:50:49 +08:00
    试试写扩展

    inline fun <reified T> T.logger(): Logger {
    return LoggerFactory.getLogger(T::class.java)
    }

    在对象里使用的时候直接 logger() 取出来

    或者再封装一次

    inline fun <reified T> T.logTrace(block: () -> String?) {
    val logger = logger()
    if (logger.isTraceEnabled) {
    logger.trace(block.invoke())
    }
    }

    在类里使用举个例子

    logTrance {
    val a = ...
    val b = ...
    "$a:$b"
    }

    Kotlin 真的很方便啊,写自己的项目都不想用 Java
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3482 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 10:40 · PVG 18:40 · LAX 02:40 · JFK 05:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.