V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
daiqiangbudainiu
V2EX  ›  Java

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

  •  
  •   daiqiangbudainiu · Jun 28, 2021 · 3091 views
    This topic created in 1768 days ago, the information mentioned may be changed or developed.
    不想每个文件都手动写 logfactory
    6 replies    2022-07-08 11:50:49 +08:00
    ipeony
        1
    ipeony  
       Jun 28, 2021
    目前在用这个库,比手写稍微方便一点
    https://github.com/MicroUtils/kotlin-logging
    yumerdev93
        2
    yumerdev93  
       Jun 28, 2021
    早上刚抄的
    yumerdev93
        3
    yumerdev93  
       Jun 28, 2021
    @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  
       Jun 28, 2021
    没有。
    hdfg159
        5
    hdfg159  
       Jun 30, 2021 via Android
    哈哈哈,没有,groovy 有
    bitmin
        6
    bitmin  
       Jul 8, 2022
    试试写扩展

    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
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2438 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 11:02 · PVG 19:02 · LAX 04:02 · JFK 07:02
    ♥ Do have faith in what you're doing.