对于我的应用程序,字符串是否为人类可读的都没有关系。
Answers:
将结构编码为字符串的一种流行方法是使用JSON。
您有某些限制,例如无法获取所有信息(例如,每个字段的特定类型),仅序列化导出的字段以及不处理递归值。但这是序列化数据的简单标准方法。
工作示例:
package main
import (
"fmt"
"encoding/json"
)
type s struct {
Int int
String string
ByteSlice []byte
}
func main() {
a := &s{42, "Hello World!", []byte{0,1,2,3,4}}
out, err := json.Marshal(a)
if err != nil {
panic (err)
}
fmt.Println(string(out))
}
给出以下输出:
{"Int":42,"String":"Hello World!","ByteSlice":"AAECAwQ="}
fmt.Sprintf
。
fmt.Sprintf
而不是Printf。如果您使用JSON,请注意,映射值可能不会在每次运行时都以相同的顺序返回(尽管fmt printf也可能是这种情况,但我没有检查)。
您还可以在该struct接收器中添加一个函数。
// URL : Sitemap Xml
type URL struct {
Loc string `xml:"loc"`
}
// URLSET : Sitemap XML
type URLSET struct {
URLS []URL `xml:"url"`
}
// converting the struct to String format.
func (u URL) String() string {
return fmt.Sprintf(u.Loc)
}
因此,打印此struct字段将返回一个字符串。
fmt.Println(urls.URLS)
使用json
或fmt.Sprintf
进行基准测试,
BenchmarkStructJson-8 1000000 1773 ns/op
BenchmarkStructSprintSharp-8 200000 6139 ns/op
BenchmarkStructSprint-8 500000 2763 ns/op
BenchmarkStructSprintPlus-8 300000 4373 ns/op
BenchmarkStructJson
正在使用json.Marshal
@Matheus Santana
BenchmarkStructSprintSharp
:`fmt.Sprintf(“%#v”,&a)@AskBjørnHansen
BenchmarkStructSprint
:`fmt.Sprintf(“%v”,&a)
BenchmarkStructSprintPlus
:`fmt.Sprintf(“%+ v”,&a)
结果是json.Marshal
更好的性能。