logging - 如何在 groovy 中为类/方法名称配置 java.util.logging?

标签 logging groovy java.util.logging

teSTLog.java:

import java.util.logging.Logger;
public class testlog {
    private final static Logger log = Logger.getLogger(testlog.class.getName());
    public static void main(String[] args) {
        System.setProperty("java.util.logging.SimpleFormatter.format","[%1$tF %1$tT]:%4$s:(%2$s): %5$s%n");
        log.info("logging test");
    }
}

执行:

$ java testlog
[2014-01-18 11:08:51]:INFO:(testlog main): logging test

测试日志.groovy:

import java.util.logging.Logger;
public class testlog {
    private final static Logger log = Logger.getLogger("testlog");
    public static void main(String[] args) {
        System.setProperty("java.util.logging.SimpleFormatter.format",'[%1$tF %1$tT]:%4$s:(%2$s): %5$s%n');
        log.info("logging test");
    }
}

执行:

$ groovy testlog
[2014-01-18 11:11:23]:INFO:(java_util_logging_Logger$info call): logging test

如何为类/方法名称配置groovy而不是“java_util_logging_Logger$info call”?

最佳答案

Groovy 通常在字节码中使用 CallSite。上面提到的 Groovy 代码将编译为以下格式的字节码:

import groovy.lang.GroovyObject;
import groovy.lang.MetaClass;
import java.util.logging.Logger;
import org.codehaus.groovy.runtime.ScriptBytecodeAdapter;
import org.codehaus.groovy.runtime.callsite.CallSite;

public class testlog
  implements GroovyObject
{
  private static final Logger log;

  static
  {
    __$swapInit();long l1 = 0L;__timeStamp__239_neverHappen1390064566496 = l1;
      long l2 = 
        1390064566495L;__timeStamp = l2;
       Object localObject = 
        $getCallSiteArray()
           [2].call(Logger.class, "testlog");log = 
           (Logger)ScriptBytecodeAdapter.castToType(localObject, Logger.class);
  }

  public static void main(String... args)
  {
    CallSite[] arrayOfCallSite = 
      $getCallSiteArray();arrayOfCallSite[0].call(System.class, 
        "java.util.logging.SimpleFormatter.format", 
                  "[%1$tF %1$tT]:%4$s:(%2$s): %5$s%n");
    arrayOfCallSite[1].call(log, "logging test");
  }

  public testlog()
  {
    testlog this;
    CallSite[] arrayOfCallSite = $getCallSiteArray();
    MetaClass localMetaClass = $getStaticMetaClass();
    this.metaClass = localMetaClass;
  }
}

因此,当从格式化程序引用时,它引用了 Log 类。要解决此问题,您可以在类级别使用 CompileStatic 注释,它将源代码按照正常的 Java 约定转换为字节码。

以下是脚本的外观(注意:- 类名称为 CamelCase):

import java.util.logging.Logger
import groovy.transform.CompileStatic

@CompileStatic
public class Testlog {
    private final static Logger log = Logger.getLogger("testlog")
    public static void main(String[] args) {
        System.setProperty("java.util.logging.SimpleFormatter.format",
            '[%1$tF %1$tT]:%4$s:(%2$s): %5$s%n')
        log.info("logging test")
    }
}

关于logging - 如何在 groovy 中为类/方法名称配置 java.util.logging?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21201305/

相关文章:

git - 如何在 Git 中显示所有已提交但尚未推送的内容?

java - Log4J2 配置中的主要参数

docker - 无法查看 ASP NET Core Container 的日志

grails - 在GSP中导入和使用Groovy代码

groovy - 使用 Groovy 脚本生成随机的 16 位十六进制数

java - 每个实例记录器,不好的做法?

java - 将 java.util.logging 重定向到 log4j

Tomcat 控制台日志从我的应用程序获取输出

logging - Kubernetes 的 Pod 日志文件在哪里?

groovy - 这个 Groovy 闭包 token '->' 有名字或昵称吗?