Go에서 문자열 배열을 바이트 배열로 인코딩 및 디코딩
문자열 배열([]string)을 바이트 배열([ ]바이트) 디스크 스토리지의 경우 최적의 솔루션에는 직렬화 형식을 고려하는 것이 포함됩니다. 다양한 형식은 다음을 포함하여 다양한 기능과 효율성 절충안을 제공합니다.
Gob:
Gob은 Go 코드에 적합한 바이너리 형식입니다. 큰 문자열 배열의 경우 공간 효율적입니다.
enc := gob.NewEncoder(file) enc.Encode(data)
디코딩의 경우:
var data []string dec := gob.NewDecoder(file) dec.Decode(&data)
JSON:
JSON은 널리 사용되는 형식입니다. . 쉽게 인코딩하고 디코딩할 수 있습니다.
enc := json.NewEncoder(file) enc.Encode(data)
디코딩의 경우:
var data []string dec := json.NewDecoder(file) dec.Decode(&data)
XML:
XML은 Gob 및 JSON에 비해 오버헤드가 더 높습니다. . 루트 및 문자열 래핑 태그가 필요합니다.
type Strings struct { S []string } enc := xml.NewEncoder(file) enc.Encode(Strings{data})
디코딩의 경우:
var x Strings dec := xml.NewDecoder(file) dec.Decode(&x) data := x.S
CSV:
CSV는 문자열 값만 처리합니다. 여러 행이나 여러 레코드를 사용할 수 있습니다. 다음 예에서는 여러 레코드를 사용합니다.
enc := csv.NewWriter(file) for _, v := range data { enc.Write([]string{v}) } enc.Flush()
디코딩의 경우:
var data string dec := csv.NewReader(file) for err == nil { s, err := dec.Read() if len(s) > 0 { data = append(data, s[0]) } }
성능 고려 사항:
최적의 형식 선택은 다음에 따라 다릅니다. 특정 요구 사항. 공간 효율성이 우선이라면 Gob과 JSON이 좋은 선택입니다. XML은 오버헤드가 높지만 복잡한 데이터 구조를 지원합니다. CSV는 간단한 문자열 배열에 가장 적합합니다.
사용자 정의 인코딩의 경우 인코딩/바이너리 패키지를 활용할 수 있지만 더 높은 수준의 구현 노력이 필요합니다.
위 내용은 Go에서 문자열 배열을 바이트 배열로 효율적으로 인코딩하고 디코딩하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!