在 Go 中获取字符串的子字符串时,不会分配新的内存。相反,子字符串的底层表示包含一个数据指针,它是原始字符串的数据指针的偏移量。
这意味着如果我有一个大字符串并希望跟踪一个小子字符串,垃圾收集器将无法释放任何大字符串,直到我释放对较短子字符串的所有引用。
slice 也有类似的问题,但您可以通过使用 copy() 制作子 slice 的副本来解决这个问题。我不知道有任何类似的字符串复制操作。制作子字符串“副本”的惯用且最快的方法是什么?
最佳答案
例如,
package main
import (
"fmt"
"unsafe"
)
type String struct {
str *byte
len int
}
func main() {
str := "abc"
substr := string([]byte(str[1:]))
fmt.Println(str, substr)
fmt.Println(*(*String)(unsafe.Pointer(&str)), *(*String)(unsafe.Pointer(&substr)))
}
输出:
abc bc
{0x4c0640 3} {0xc21000c940 2}
关于string - 子字符串和 Go 垃圾收集器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16909917/