java.time이 초 단위 구문 분석을 처리할 수 있나요?
문제 개요:
Java 8에서는 java.time 패키지를 사용하여 초 단위 구문 분석 시도가 처음에는 성공했지만 나중에 예외가 발생했습니다. 이 오류는 밀리초 동안 형식 지정 패턴에 "SS"를 통합하는 경우에도 지속되었습니다. 입력 숫자와 동일한 수의 형식 문자가 필요함을 나타내는 문서에도 불구하고 엄격한 모드 시행은 분수 문자 부족을 잘못 해석했습니다.
해결책:
이 문제는 Java 9에서 해결됩니다. 그때까지는 인접 값 구문 분석과 관련된 해결 방법을 사용할 수 있습니다.
<code class="java">DateTimeFormatter dtf = new DateTimeFormatterBuilder() .appendPattern("yyyyMMddHHmmss") .appendValue(ChronoField.MILLI_OF_SECOND, 3) .toFormatter();</code>
그러나 이 접근 방식은 SS에서 소수 두 자리 숫자의 특정 인스턴스를 처리하지 않습니다.
기술적 배경:
패턴 기호 "S"는 나노초를 포함하여 1초의 모든 부분을 나타냅니다. 인접 값 구문 분석을 사용하면 파서가 리터럴 또는 시간 부분 구분 기호로 구분된 필드를 기술할 수 있습니다.
대체 솔루션:
인접 값 구문 분석 관리 시 JSR-310의 제한으로 인해 대체 솔루션 존재:
<code class="java">SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSS"); Date d = sdf.parse(input);</code>
<code class="java">// Joda-Time DateTimeFormatter dtf = DateTimeFormat.forPattern("yyyyMMddHHmmssSS");</code>
<code class="java">// Time4J ChronoFormatter<PlainTimestamp> f = ChronoFormatter.ofTimestampPattern("yyyyMMddHHmmssSS", PatternType.CLDR, Locale.ROOT);</code>
<code class="java">String input = "2011120312345655"; DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyyMMddHHmmss"); int len = input.length(); LocalDateTime ldt = LocalDateTime.parse(input.substring(0, len - 2), dtf); int millis = Integer.parseInt(input.substring(len - 2)) * 10; ldt = ldt.plus(millis, ChronoUnit.MILLIS);</code>
위 내용은 Java.time이 1초 단위의 부분을 정확하게 구문 분석할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!