我想在GO中将字符串数组转换为字节数组,以便可以将其写到磁盘上。将字符串数组([]string)解码为字节数组([]byte)的最佳解决方案是什么?
[]string
[]byte
我正在考虑对字符串数组进行两次迭代,第一个迭代以获得字节数组所需的实际大小,然后第二个迭代写入[]byte(str)每个元素的长度和实际字符串()。
[]byte(str)
解决方案必须能够以其他方式进行转换;从一个[]byte到一个[]string。
让我们忽略一个事实,那就是走一秒钟。您需要做的第一件事是将序列化格式编组[]string为。
这里有很多选择。您可以构建自己的库或使用库。我将假设您不想构建自己的格式,而跳到支持序列化的格式。
在所有示例中,data是[]string您正在读取/写入的文件,而fp是您正在读取/写入的文件。错误被忽略,请检查函数的返回值以处理错误。
Gob是只能执行的二进制格式。随着字符串数量的增加,它应该相对节省空间。
enc := gob.NewEncoder(fp) enc.Encode(data)
阅读也很简单
var data []string dec := gob.NewDecoder(fp) dec.Decode(&data)
采空区很简单而且很关键。但是,该格式仅可与其他Go代码一起读取。
接下来是json。Json是一种几乎在所有地方都使用的格式。这种格式易于使用。
enc := json.NewEncoder(fp) enc.Encode(data)
并阅读:
var data []string dec := json.NewDecoder(fp) dec.Decode(&data)
XML是另一种常见格式。但是,它具有很高的开销,并且不那么容易使用。尽管您可以像对gob和json一样进行操作,但正确的xml需要一个根标签。在这种情况下,我们使用根标签“ Strings”,每个字符串都包装在“ S”标签中。
type Strings struct { S []string } enc := xml.NewEncoder(fp) enc.Encode(Strings{data}) var x Strings dec := xml.NewDecoder(fp) dec.Decode(&x) data := x.S
CSV与其他不同。您有两种选择,使用一条记录包含n行或n条记录包含1行。下面的示例使用n条记录。如果我使用一张记录,那会很无聊。看起来太像其他了。CSV只能容纳字符串。
enc := csv.NewWriter(fp) for _, v := range data { enc.Write([]string{v}) } enc.Flush()
阅读:
var err error var data string dec := csv.NewReader(fp) for err == nil { // reading ends when an error is reached (perhaps io.EOF) var s []string s, err = dec.Read() if len(s) > 0 { data = append(data, s[0]) } }
您使用哪种格式是优先选择的问题。我还没有提到许多其他可能的编码。例如,有一个名为bencode的外部库。我个人不喜欢bencode,但是可以。它与bittorrent元数据文件使用的编码相同。
如果要进行自己的编码,那么编码/二进制是一个不错的起点。这样可以使最紧凑的文件成为可能,但我认为值得付出努力几乎没有。