我有以下代码,这在我的应用程序中主要是时间复杂度最高的。
public class Test {
private static final DateTimeFormatter SQL_FORMATTER = DateTimeFormatter.ofPattern("MM/dd/yy HH:mm:ss");
public static void main(String[] args) {
Instant start = Instant.now();
try {
String parsedDate = parseISO8601UtcDateToSqlDateFormat("2000-01-01T00:00:00Z");
System.out.println(parsedDate);
} finally {
long timeTaken = Duration.between(start, Instant.now()).toMillis();
System.out.println("\n\nFinished processing in: "+timeTaken+ " ms!\n");
}
}
public static String parseISO8601UtcDateToSqlDateFormat(String param) {
TemporalAccessor accessor = DateTimeFormatter.ISO_INSTANT.parse(param);
LocalDateTime dateTime = LocalDateTime.ofInstant(Instant.from(accessor), ZoneOffset.UTC);
return dateTime.format(SQL_FORMATTER);
}
}
日期时间格式化至少消耗 16ms 。
而我的完整应用程序执行大量复杂处理的时间少于 1ms 。
P.S:问题与基准测试无关,我只是想了解使用java 8解析日期时间是否真的很昂贵,或者我做错了什么。
答案 0 :(得分:1)
你试过了吗?
private static final DateTimeFormatter SQL_FORMATTER = DateTimeFormatter.ofPattern(SQLFormatConstants.JAVA_DATE_FORMAT);
private String parseISO8601UtcDateToSqlDateFormat(String param) {
TemporalAccessor accessor = DateTimeFormatter.ISO_INSTANT.parse(param);
LocalDateTime dateTime = LocalDateTime.ofInstant(Instant.from(accessor), ZoneOffset.UTC);
return dateTime.format(SQL_FORMATTER);
}
New Java 8 Time API具有无状态和不可变格式化程序。自定义格式化程序应编译一次并存储在常量中(如DateTimeFormatter.ISO_INSTANT
)。