[心凉半截]怎么到处都是陷阱?golang,我总觉得好危险。

cq441745656 · · 2536 次点击
没事,多喷下就会了,才开始用。
#9
更多评论
........看了楼主的例子,让你不能理解的是这段,因为这段导致的你不能理解,这段代码你执行的有错误,可以单独的拿出来重新执行一下看一看到底有什么结果。 ```go fmt.Println("without assign:", append(slc[:3], Score{12})) fmt.Println("slc2: ", slc)· // 输出 //without assign: [{10} {9} {7} {6} {5} {4} {3} {2} {1} {0} {12}] //slc 2 [{10} {9} {7} {6} {5} {4} {3} {2} {1} {0}] // 描述:without assign预期为[0,3) + 12 = {{0},{1},{2},{12}} 呀,与预期结果不符合, slc2未变,是否表示对切片的分段的操作,不改变切片自身的值。 ``` 这段的输出“without assign:"值是错误的,你可以再操作一下,应该是预期输出才对。 对于slice的append的确比较难理解,但只要你理解了slice的概念,就比较好理解append的用法了。文档已经说明了append函数:如果slice的capacity够用(这里的capacity指的是该slice指向的底层数组),就会在原slice后追加元素。否则会分配新的空间来存储。那原slice还是原来那个不变,append函数返回的新slice指向了新的底层数组。append函数底层的实现比较复杂,不要去猜测某次append后cap是否够用,是否分配了新的空间。 在使用append函数时为了保证你要得到想要的结果,将append返回的值重新赋值给你的slice就好了。
#1
楼上已经解释很清楚了。但我还不明白语言这样设计的用意。 题主可以考虑使用2个方法: 1、使用完整的 slice 生成表达式(带 cap),这样在 append 时,由于cap 不足就会重新分配底层数组,但修改操作还是会影响原 slice; 2、生成新 slice 时,使用 copy 拷贝,这样避免影响原 slice
#2