UTF-8 문자열을 []바이트로 역마샬링
JSON으로 작업할 때 역마샬링 기능에는 []바이트 유형의 입력이 필요합니다. 그러나 데이터는 UTF-8 문자열로 저장될 수 있습니다. 이 기사에서는 성공적인 언마샬링을 위해 UTF-8 문자열을 []바이트로 변환하는 방법을 살펴봅니다.
[]바이트(s)를 사용한 변환
Go 사양에 따라 , 간단한 캐스팅을 사용하여 문자열을 []byte로 변환할 수 있습니다.
<code class="go">s := "some text" b := []byte(s)</code>
그러나 이 변환은 문자열 내용의 복사본을 생성하므로 큰 문자열의 경우 비효율적일 수 있습니다.
효율적인 비정렬화를 위해 io.Reader 사용
대체 접근 방식은 다음 문자열에서 생성된 io.Reader를 사용하는 것입니다.
<code class="go">s := `{"somekey":"somevalue"}` reader := strings.NewReader(s) decoder := json.NewDecoder(reader) var result interface{} decoder.Decode(&result)</code>
이 방법은 문자열 복사를 방지하고 큰 입력에는 더 효율적입니다.
다양한 시나리오에 대한 고려 사항
요약하면 UTF-8 문자열을 변환하면 언마샬링을 위한 []byte로의 변환에는 대규모 입력을 효율적으로 처리하기 위해 직접 캐스팅하거나 io.Reader를 사용하는 것이 포함됩니다. 선택은 애플리케이션의 특정 요구 사항에 따라 달라집니다.
위 내용은 Go에서 JSON Unmarshalling을 위해 UTF-8 문자열을 []byte로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!