go语言copy go语言copy函数( 四 )


aa bb cc dd ee
~~~~~~修改~~~~~~
[9 9 9 9 9]
(4)、追加、复制切片:
复制代码代码如下:
func test11() {
slice := []int32{}
fmt.Printf("slice的长度为:%d,slice为:%v\n", len(slice), slice)
slice = append(slice, 12, 11, 10, 9)
fmt.Printf("追加后,slice的长度为:%d,slice为:%v\n", len(slice), slice)
slicecp := make([]int32, (len(slice)))
fmt.Printf("slicecp的长度为:%d,slicecp为:%v\n", len(slicecp), slicecp)
copy(slicecp, slice)
fmt.Printf("复制赋值后 , slicecp的长度为:%d,slicecp为:%v\n", len(slicecp), slicecp)
}
追加、复制切片,用的是内置函数append和copy,copy函数返回的是最后所复制的元素的数量 。
(5)、内置函数append
内置函数append可以向一个切片后追加一个或多个同类型的其他值 。如果追加的元素数量超过了原切片容量,那么最后返回的是一个全新数组中的全新切片 。如果没有超过,那么最后返回的是原数组中的全新切片 。无论如何,append对原切片无任何影响 。如下示例:
复制代码代码如下:
func test12() {
slice := []int32{1, 2, 3, 4, 5, 6}
slice2 := slice[:2]
_ = append(slice2, 50, 60, 70, 80, 90)
fmt.Printf("slice为:%v\n", slice)
fmt.Printf("操作的切片:%v\n", slice2)
_ = append(slice2, 50, 60)
fmt.Printf("slice为:%v\n", slice)
fmt.Printf("操作的切片:%v\n", slice2)
}
如上,append方法用了2次,结果返回的结果完全不同,原因是第二次append方法追加的元素数量没有超过 slice 的容量 。而无论怎样,原切片slice2都无影响 。结果:
slice为:[1 2 3 4 5 6]
操作的切片:[1 2]
slice为:[1 2 50 60 5 6]
操作的切片:[1 2]
go语言copy函数介绍的疑惑go语言go语言copy()我不懂,但是看似乎懂go语言copy()了,仅供参考
意思是源和目标可以为同一目标,复制go语言copy()的数量是源或者目标的元素最小数量
比如例子中的copy(s,a[0]:)
a虽然一共有8个元素,但是s只有6len(det)个元素 ,看上面的makeint是6
所以这里只复制go语言copy()了最小数量6个元素,因此a的012345被复制进了s
第二个
copy(s,s[2]:)
这里是从s[2]开始,所以len是6-2=4,而且因为46 , 只复制4个元素
因此
0 1 2 3 4 5 复制后4个元素到前面结果就是go语言copy():
2 3 4 5 4 5 //这个就是可以源和目标可重叠,
上面的也说明了按照len(str)和len(det)中最少值
关于go语言copy()和go语言copy函数的介绍到此就结束了 , 不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

推荐阅读