Java 8 초기 릴리스에서는 java.time을 사용하여 단위 초 단위 구문 분석을 수행했습니다. 패키지에서 예외가 발생할 수 있습니다. 다음 코드를 고려하십시오.
<code class="java">String input = "2011120312345655"; DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMddHHmmssSS"); LocalDateTime localDateTime = LocalDateTime.parse(input, formatter);</code>
이 코드는 예외로 인해 실패합니다.
java.time.format.DateTimeParseException
문서에는 엄격 모드에서 입력 숫자와 동일한 수의 형식 문자가 필요하다고 명시되어 있습니다. 그러나 코드에는 입력의 자릿수와 모순되는 초 단위의 "SS"가 포함되어 있습니다.
이 문제를 해결하기 위해 해결 방법이 제안되었습니다.
<code class="java">DateTimeFormatter dtf = new DateTimeFormatterBuilder() .appendPattern("yyyyMMddHHmmss") .appendValue(ChronoField.MILLI_OF_SECOND, 3) .toFormatter();</code>
그러나 이 해결 방법은 두 개의 "S" 패턴 기호만 사용하는 경우에는 완전히 적용되지 않습니다. MICRO_OF_SECOND(6 SSSSSS) 또는 NANO_OF_SECOND(9 SSSSSSSSS)와 같은 다른 필드를 사용해야 합니다.
문서에 따르면:
"분수: 나노초 필드를 분수로 출력합니다. (...) 엄격 모드에서 구문 분석할 때 구문 분석된 자릿수는 패턴 문자의 개수와 일치해야 합니다."
이는 "S"가 밀리초가 아니라 초의 모든 부분을 나타냄을 의미합니다. .
Java 9부터 해당 문제가 해결되었습니다. Java 8의 초기 릴리스에서는 소수 부분에 대한 인접 값 구문 분석을 구현하는 데 어려움을 겪었습니다. 이러한 제한으로 인해 명확한 경계 없이 여러 필드에 걸쳐 있는 텍스트의 필드를 해석하는 데 방해가 되었습니다.
그러나 Java 9에서는 JSR-310 파서가 인접 값 구문 분석에서 소수 부분을 구문 분석하는 기능을 얻었습니다. 이러한 개선 사항은 이전 버전에서 직면했던 문제를 해결하고 초 단위 값으로 작업할 때 향상된 유연성을 제공합니다.
위 내용은 Java 8의 `java.time` 패키지가 엄격 모드에서 초 단위 값을 구문 분석하지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!