我想使用": "连接net.Addr和[]rune的文本表示,从而生成一个新的[]rune。做这件事最常用的方式是什么?
我目前有(出于示例目的,使用空格和显式类型):
var (
netAddr net.Addr
someRunes []rune
_ []rune = append(
append(
[]rune(netAddr.String()),
[]rune(": ")...),
someRunes...
)
)发布于 2013-06-01 05:55:22
如果你只是想让你的代码清晰易懂,你可以这样做:
[]rune(netAddr.String() + ": " + string(someRunes))这是低效的,因为里面有一些不必要的副本,但它以一种人类可以轻松阅读的方式传达了逻辑。如果您的分析器后来告诉您这是一个瓶颈,那么您的多重追加解决方案可能仍然会执行比必要的更多的复制/分配。我会这样做:
sep := []rune(": ")
addr := []rune(netAddr.String())
newRuneSlice = make([]rune, 0, len(addr) + len(sep) + len(someRunes))
newRuneSlice = append(newRuneSlice, addr...)
newRuneSlice = append(newRuneSlice, sep...)
newRuneSlice = append(newRuneSlice, someRunes...)我的猜测是,您的分析器不会告诉您这是一个瓶颈,所以one liner很可能是最好的。但是,您应该知道,one liner只适用于有效的unicode。如果你的符文片段中有无效的代码点或代理对(从Go 1.1开始),你将以错误符文代替它们而结束。对于大多数情况,这不是问题,但它值得考虑。
示例:http://play.golang.org/p/AFoBX_2Wem
invalid := utf8.MaxRune + 1
fmt.Println([]rune(string(invalid))[0] == utf8.RuneError) // prints true发布于 2013-06-01 02:04:50
[]rune(netAddr.String()+": ")首先要清楚和仔细考虑,如果有问题,以后再优化。
https://stackoverflow.com/questions/16860654
复制相似问题