Time.Parse: 정확한 구문 분석으로 시간대 미로 탐색
Go의 시간 조작은 강력한 기능 세트를 제공합니다. time 패키지의 중추적인 기능인 Time.Parse는 시간 값을 나타내는 문자열을 Go의 내부 시간 구조로 꼼꼼하게 변환하는 데 사용됩니다. 그러나 Time.Parse로 시간을 구문 분석할 때 많은 개발자는 당황스러운 문제에 직면합니다. 왜 항상 시간대 정보를 고려하지 않습니까?
불일치 공개
To 동작을 설명하고 다음 코드를 살펴보겠습니다. snippet:
package main import ( "fmt" "time" ) func main() { t, err := time.Parse("2006-01-02 MST", "2018-05-11 IST") if err != nil { return } t2, err := time.Parse("2006-01-02 MST", "2018-05-11 UTC") if err != nil { return } fmt.Println(t.Unix()) fmt.Println(t2.Unix()) }
직관적으로 시간대가 다르기 때문에 출력 타임스탬프도 다를 것으로 예상할 수 있습니다. 놀랍게도 코드는 IST와 UTC 사이의 명확한 오프셋에도 불구하고 두 타임스탬프에 대해 동일한 값을 생성합니다.
이론 탐구
이 동작의 이유는 다음과 같습니다. Parse 함수에 사용되는 시간 레이아웃에 명시적인 시간대 정보가 없습니다. 기본적으로 Parse는 알 수 없는 시간대 약어를 오프셋이 0인 가상 위치로 처리하여 IST에서 지정한 오프셋을 효과적으로 무시합니다. 결과적으로 두 타임스탬프가 모두 UTC 시간대에 있는 것으로 구문 분석되어 동일한 Unix 타임스탬프 값이 생성됩니다.
시간대 복잡성 탐색
이 문제를 해결하고 다음을 사용하여 시간을 구문 분석합니다. 정확한 시간대 정보를 제공하며 다양한 옵션을 제공합니다:
1. 명시적 숫자 오프셋 지정:
시간대 약어에 의존하는 대신 시간 레이아웃에서 오프셋을 명시적으로 지정합니다. 예:
t, err := time.Parse("2006-01-02 -0700", "2018-05-11 +0530")
2. ParseInLocation 활용:
파싱을 위한 사용자 정의 시간대 위치를 지정할 수 있는 ParseInLocation 함수를 활용하세요. 이 기술은 시간대 처리에 대한 보다 세부적인 제어를 제공합니다. 예를 들면 다음과 같습니다.
loc, err := time.LoadLocation("Asia/Kolkata") t, err := time.ParseInLocation("2006-01-02 MST", "2018-05-11 IST", loc)
이러한 전략을 채택하면 올바른 시간대 정보로 시간 값을 효과적으로 구문 분석하여 다양한 시나리오에서 정확한 시간 조작이 가능해집니다.
위 내용은 Go의 `Time.Parse`가 항상 시간대 정보를 존중하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!