Java 8 DateTimeFormatter性能

时间:2018-03-05 18:30:29

标签: java performance java-8 java-date

我有以下代码,这在我的应用程序中主要是时间复杂度最高的。

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解析日期时间是否真的很昂贵,或者我做错了什么。

1 个答案:

答案 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)。