作为一名java开发者,我们会经常使用到String.format()来格式化字符串,但这种方式存在以下缺点:
- 不同的数据类型需要使用不同的占位符
- 当格式化的字符串是全英文且字符串长度较长时,导致占位符与字符串混淆在一起,不好一眼识别
最近因为一次不注意,字符串格式化中有几个不同类型的数据类型,导致了报错。就想到有没有更好的格式化字符串方法,发现日常我们使用的Slf4j打印日志时,都是统一使用{}来当占位符`,如下:
log.info("打印日志:{},时间戳:{}", "XXXXXXXX", System.currentTimeMillis());
在slf4j-api的包下,发现有类似日志打印的格式化工具类:org.slf4j.helpers.MessageFormatter
public static void main(String[] args) {
String messageFormat = MessageFormatter.format("hi, {}, are u ok?", "james").getMessage();
System.out.println(messageFormat);
}

要是嫌调用方法过长,每次都要.getMessage(),可以自己封装下
Java开发者常使用特定方式格式化字符串,但存在不同数据类型需不同占位符、长英文串中占位符难识别等缺点。作者因一次格式化报错,想到寻找更好方法,发现日常打印日志用统一占位符,还在特定包下找到类似格式化工具类,也可自行封装。
832

被折叠的 条评论
为什么被折叠?



