Java 8 DateTimeFormatter性能[重复]

问题描述 投票:0回答:1

这个问题在这里已有答案:

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

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);

    }

}

日期时间格式化至少需要16毫秒。

而我的完整应用程序可以在不到1毫秒的时间内完成大量复杂的处理。

P.S:问题与基准测试无关,我只是想了解使用java 8解析日期时是否真的很昂贵,或者我做错了什么。

java performance java-8 java-date
1个回答
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);
}

新的Java 8 Time API具有无状态和不可变的格式化程序。自定义格式化程序应编译一次并存储在常量中(如DateTimeFormatter.ISO_INSTANT)。

© www.soinside.com 2019 - 2024. All rights reserved.