16진수를 IEEE-754 Float로 변환
"0xC40C5253"과 같은 16진수 문자열을 IEEE-754 float 값으로 변환하려면 표준 strconv. ParseFloat 기능이 충분하지 않습니다. 이 기사에서는 이 변환을 수행하는 대체 방법을 살펴봅니다.
먼저 입력의 비트 길이를 결정합니다. 이 경우 8자리 16진수는 32비트 부동 소수점일 가능성이 높습니다(사용자의 확인이 권장됨).
strconv.ParseUint 및 안전하지 않은 변환 사용:
코드:
s := "C40C5253" n, err := strconv.ParseUint(s, 16, 32) if err != nil { panic(err) } n2 := uint32(n) f := *(*float32)(unsafe.Pointer(&n2))
math.Float32frombits를 사용하는 대안:
수학 패키지는 다음을 제공합니다. 직접 변환하는 내장 함수 Float32frombits() uint32를 float32로 변환합니다.
코드:
f := math.Float32frombits(n2)
사용:
이제 두 가지 방법 중 하나로 액세스할 수 있습니다. f에 저장된 float 값. 예:
fmt.Println(f) // Output: -561.2863
위 내용은 Go에서 16진수 문자열을 IEEE-754 부동 소수점으로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!