Is there a Java 1.5 varargs API for slf4j yet?

2019-04-18 00:11发布

I want to get rid of this lot...

public void info(String msg);
public void info(String format, Object arg);
public void info(String format, Object arg1, Object arg2);
public void info(String format, Object[] argArray);

...and replace it with this one...

public void info(String format, Object ... args);

...so that my logging syntax doesn't have to change depending on the number of arguments I want to log. There seems to be lots of discussion and work around it, but where is it? Or should I wrap the wrapper that is slf4j?

7条回答
做自己的国王
2楼-- · 2019-04-18 00:29

What about this:

package util;

public class Util {
  public static Object[] va(Object... args) {
    return args;
  }
}

package foo;
import static util.Util.va;
...
 logger.info("a {}, b {}, c c {}", va("A", "B", "C"));
...

you can use va() in other places too.

查看更多
放我归山
3楼-- · 2019-04-18 00:34

This is finally solved. SLF4J 1.7.0 now required JDK 1.5 and has backward-compatible varargs methods.

查看更多
姐就是有狂的资本
4楼-- · 2019-04-18 00:34

From reading the SLF4J javadoc for Logger the simple answer would appear to be no. From what I have read they want to stay compatible with older versions of the JDK.

If you are not really tied to using SLF4J then maybe log5j is an option?

查看更多
该账号已被封号
5楼-- · 2019-04-18 00:43

No.

The issue is still open how to do it right while still maintaining 100% backwards compatibility.

Feel free to see the discussion at http://bugzilla.slf4j.org/show_bug.cgi?id=31

查看更多
戒情不戒烟
6楼-- · 2019-04-18 00:53

The real question is "Why must a jdk < 5 be supported by this any longer"? If you have an older version of java, then use the older API. It's that simple. Why not make this fit better into the current java world? I mean, JDK 5 isn't even supported without a support contract from Sun/Oracle. Backward compatibility is a joke in this case.

查看更多
何必那么认真
7楼-- · 2019-04-18 00:53

There is a solution of using varargs with SLF4J.

There is an open source project called Lumberjack that extends SLF4J to provides varargs logging methods. The extension is very natural, you don't feel any difference compared to using SLF4J (this is because Lumberjack is only a wrapper around SLF4J, so all the functionality is still provided by SLF4J).

Example usage:

JackLogger logger = JackLoggerFactory.getLogger(LoggerFactory.getLogger(Weather.class));

logger.info("Hello {}! The current time is {}:{}:{}, and after {} hours the weather will be {}.", "Jack", 13, 30, 0, 5, "sunny");

Lumberjack website: https://github.com/bogdanu/lumberjack

The Lumberjack license is the same as SLF4J's license, the MIT license, so there is no additional licensing restriction.

Disclaimer: I am the author of Lumberjack

查看更多
登录 后发表回答