在Go中获取字符串的子字符串时,不会分配新的内存。而是,子字符串的基础表示形式包含一个Data指针,该指针是原始字符串的Data指针的偏移量。

这意味着,如果我有一个大字符串并且希望跟踪一个小子字符串,则垃圾收集器将无法释放任何大字符串,直到我释放所有对短子字符串的引用为止。

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/

10-08 23:16