![将[]字符串转换为[]字节,第1张 将[]字符串转换为[]字节,第1张](/aiimages/%E5%B0%86%5B%5D%E5%AD%97%E7%AC%A6%E4%B8%B2%E8%BD%AC%E6%8D%A2%E4%B8%BA%5B%5D%E5%AD%97%E8%8A%82.png)
让我们忽略一个事实,那就是走一秒钟。您需要做的第一件事是将序列化格式编组
[]string为。
这里有很多选择。您可以构建自己的库或使用库。我将假设您不想构建自己的格式,而跳到支持序列化的格式。
在所有示例中,data是
[]string您正在读取/写入的文件,而fp是您正在读取/写入的文件。错误被忽略,请检查函数的返回值以处理错误。地精
Gob是只能执行的二进制格式。随着字符串数量的增加,它应该相对节省空间。
enc := gob.NewEnprer(fp)enc.Enpre(data)
阅读也很简单
var data []stringdec := gob.NewDeprer(fp)dec.Depre(&data)
采空区很简单而且很关键。但是,该格式仅可与其他Go代码一起读取。
杰森接下来是json。Json是一种几乎在所有地方都使用的格式。这种格式易于使用。
enc := json.NewEnprer(fp)enc.Enpre(data)
并阅读:
XML格式var data []stringdec := json.NewDeprer(fp)dec.Depre(&data)
XML是另一种常见格式。但是,它具有很高的开销,并且不那么容易使用。尽管您可以像对gob和json一样进行 *** 作,但正确的xml需要一个根标签。在这种情况下,我们使用根标签“
Strings”,每个字符串都包装在“ S”标签中。
type Strings struct { S []string}enc := xml.NewEnprer(fp)enc.Enpre(Strings{data})var x Stringsdec := xml.NewDeprer(fp)dec.Depre(&x)data:= x.SCSVCSV与其他不同。您有两种选择,使用一条记录包含n行或n条记录包含1行。下面的示例使用n条记录。如果我使用一张记录,那会很无聊。看起来太像其他了。CSV只能容纳字符串。
enc := csv.NewWriter(fp)for _, v := range data { enc.Write([]string{v})}enc.Flush()阅读:
var err errorvar data stringdec := 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]) }}您使用哪种格式是优先选择的问题。我还没有提到许多其他可能的编码。例如,有一个名为benpre的外部库。我个人不喜欢benpre,但是可以。它与bittorrent元数据文件使用的编码相同。
如果要进行自己的编码,那么编码/二进制是一个不错的起点。这样可以使最紧凑的文件成为可能,但我认为值得付出努力几乎没有。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)