我正在尝试更好地理解 go。我为自己创建了一个小练习:将指针切片传递给函数并修改它。
这就是我想出的:
package main
import (
"fmt"
"unsafe"
)
func main() {
var data *[]byte
fillData(data)
fmt.Println((*data)[0:5])
}
func fillData(data *[]byte) {
b := []byte("hello")
fmt.Println(b[0:5])
fmt.Println(string(b[0:5]))
data = (*[]byte)(unsafe.Pointer(&b[0]))
}
但它给出了一个invalid memory address or nil pointer dereference
错误。我知道我不会在实际代码中使用这样的东西,但我只是好奇如何传递切片并修改它而不返回它。
https://play.golang.org/p/_K5ltKKKNV https://play.golang.org/p/_K5ltKKKNV
当您尝试更新时data
in fillData
,你犯了两个错误。首先,您更新指针而不是它所指向的内容。第二,data
是一个 nil 指针,因此通过该指针写入将导致 nil 指针错误。
这是编写代码的一种可能的方法。data
以归零切片开始,并在内部更新fillData
。这将从中复制切片信息(len、cap 和指向数组的指针)b
to *data
意思就是data
将与分享信息b
(重要的是,包括共享底层数组)。
package main
import "fmt"
func main() {
var data []byte
fillData(&data)
fmt.Println(data, data[0:5])
}
func fillData(data *[]byte) {
b := []byte("hello")
*data = b[0:1]
}
另一种方法是data
作为一个指针,并更新它。然后你必须将一个双指针传递给fillData
。那看起来像这样:
package main
import "fmt"
func main() {
var data *[]byte
fillData(&data)
fmt.Println((*data)[0:5])
}
func fillData(data **[]byte) {
b := []byte("hello")
*data = &b
}
最后,编写此代码的最佳方法是根本不使用指针,而只返回切片。与 C 或 C++ 不同,很少需要对函数使用“输出”参数。那是因为 go 允许多个返回值。
package main
import "fmt"
func main() {
data := getData()
fmt.Println(data, data[0:5])
}
func getData() []byte {
return []byte("hello")[:1]
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)