问题内容
不知道该说什么,只看代码和输出。
代码:
package main
import (
"encoding/json"
"fmt"
)
type Human struct {
N string `json:"n"`
C string `json:"c"`
}
func funcname(jDL ...[]byte) {
jDL_len := len(jDL)
people := [][]Human{}
var buf []Human
var err error
for i := 0; i 登录后复制
输出:
buf 0 [{Alice A1} {Bob A2}]
people 0 [[{Alice A1} {Bob A2}]]
buf 1 [{Clark B1} {Davis B2}]
people 1 [[{Clark B1} {Davis B2}] [{Clark B1} {Davis B2}]]
jsoned [[{"n":"Clark","c":"B1"},{"n":"Davis","c":"B2"}],[{"n":"Clark","c":"B1"},{"n":"Davis","c":"B2"}]]
err
登录后复制
查看输出中的 people 0 和 people 1 字符串。我使用 append 来合并 buf 0 和 buf 1,因此输出中的 people 1 字符串应如下所示:
[[{Alice A1} {Bob A2}]] [{Clark B1} {Davis B2}]
,即数组的第一个元素更改为插入的元素,尽管不应该如此。可能是什么原因以及如何解决它?
我没有尝试进行任何修复,因为我在代码中没有发现任何问题。
正确答案
虽然我同意其他人的评论,即修复方法是将 buf
变量移动到 for 循环内,但我也相信这种混乱源于 buf
是一个切片,也许 OP 不知道切片是如何工作的。切片与数组不同,如 Go 切片:用法和内部中所述。
切片
引用来源的关键句子:
考虑到这一点,请看以下简化示例:
package main
import "fmt"
func main() {
slice := [][]int{}
buf := []int{0} // Slice
for i := 0; i 登录后复制
输出:[[2] [2] [2]]
这是OP在他们的示例中观察到的行为。由于切片是指向数组的指针,因此需要在 for 循环内声明 buf
,以便每次迭代附加不同的实例。
现在让我们看看如果我们对数组执行相同的操作会发生什么。
数组
引用来源的关键句子:
现在让我们看一个示例,该示例演示了在传递数组时(即,将其传递给 append
时)由数组内容组成的副本:
package main
import "fmt"
func main() {
slice := [][1]int{}
buf := [1]int{} // Array
for i := 0; i 登录后复制
输出:[[0] [1] [2]]
现在,尽管 for 循环中使用了相同的 buf
变量,但所有值都不同了。
以上就是Go:附加第二项更改第一项的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!