我有一片uuid.UUID元素。从源代码来看, auuid.UUID只是字节数组的类型别名:type UUID [16]byte。我正在尝试使用以下代码将这片uuid.Uuids转换为 s 片:[]bytepackage mainimport ( "fmt" "github.com/google/uuid")func main() { ids := []uuid.UUID { uuid.New(), uuid.New(), uuid.New(), } fmt.Printf("ids: %v\n", ids) idBytes := make([][]byte, len(ids)) for i, id := range ids { idBytes[i] = id[:] } fmt.Printf("idBytes: %x\n", idBytes)}出于某种原因,这会产生以下输出:ids: [66b4bb26-3c1f-4dd7-a608-aa8f799e4bfe 014e0537-c326-4021-be38-165f49595eed 5c71efff-ddb5-4f6e-8f85-c1dab013b5d1]
idBytes: [5c71efffddb54f6e8f85c1dab013b5d1 5c71efffddb54f6e8f85c1dab013b5d1 5c71efffddb54f6e8f85c1dab013b5d1]显然有 3 个不同的 UUID,但输出切片仅包含最后一个,重复 3 次。这里发生了什么?我尝试过的事情:使用非切片类型而不是切片类型(即使用 []uint64 作为输入和输出而不是 []uuid.UUID 和 [][]byte)。这显示了预期的行为(我看到 3 个不同的值而不是最后一个值重复 3 次),但它实际上并没有解决我的问题。只设置最后一个元素(把idBytes[i] = id[:]里面的一个if i == len(ids) - 1块)。这仅设置最后一个元素(前两个元素保持为零)。
1 回答
UYOU
TA贡献1878条经验 获得超4个赞
需要考虑的两个事实:
id
是 UUID 类型,即[16]byte
.循环变量 a 在每次迭代时被覆盖
因此,在 for 循环的所有迭代之间只有一个 is 实例id
被分配和共享。由于id
是一个数组(不是切片),因此每个 UUID 的内容都被复制到id
. 因此,所有 slice 都id[:]
指向同一个共享的底层字节数组,当循环结束时,该数组包含id
.
修理:
idBytes[i] = ids[i][:]
这将为每个 UUID 创建单独的切片。
- 1 回答
- 0 关注
- 79 浏览
添加回答
举报
0/150
提交
取消