假设我有一个字符串 s。
s := "helloworld"
现在,我的问题是,如果 s 有“n”个字节,那么如果我将 s 传递给一个函数,而不是将 &s 传递给一个函数然后访问字符串的第 i 个字节,那么相对于“n”的时间复杂度是多少。
如果将 &s 传递给函数并访问字符串的第 i 个字节需要 O(1) 时间,那么当我将 s 传递给函数然后访问字符串的第 i 个字节时是否需要 O(n) 时间(因为整个字符串将被复制)?
我试过了,发现复制一个字符串确实会改变指向它的指针。希望能更清楚地说明这一点。
func main() {
str := "helloworld"
fmt.Println("string pointer 1:", &str)
printStringPointer(str)
}
func printStringPointer(s string) {
fmt.Println("string pointer 2:", &s)
}
输出:
string pointer 1: 0xc000010200
string pointer 2: 0xc000010210
蝴蝶刀刀
相关分类