语义理解切片
go 语言中的切片是 go 语言的一个特色,从语义上来说,切片就是把一个整体的东西切分成小的部分,那么对于语言中的切片也是同理。
举个例子看如下代码:
package main import "fmt" func main() { arr := [...]int{0, 1, 2, 3, 4, 5, 6, 7} fmt.Println("arr[2:6]:", arr[2:6]) // 从下标2到下标6 fmt.Println("arr[:6]:", arr[:6]) // 从下标0到下标6 fmt.Println("arr[2:]:", arr[2:]) // 从下标2到最后 fmt.Println("arr[:]:", arr[:]) // 全部 }
输出结果为:
arr[2:6]: [2 3 4 5]
arr[:6]: [0 1 2 3 4 5]
arr[2:]: [2 3 4 5 6 7]
arr[:]: [0 1 2 3 4 5 6 7]
这里可以很明确的看出,我们想要 arr 数组的哪一部分,我们就切哪一部分。
当然,如果仅仅知道切片是这么用的当然还不够,我们应该更加深入的理解,如:
对原数组的 copy 还是 view 。
对于 go 语言的数组,copy 和 view 是同时都存在的。
- copy 就是使用这个数组的时候我将这个数组拷贝一份,这样对于数组的增删改,是不会改变原数组的值的
- view 由数组执行切片所返回的对象是一个 view,即视图,若我们在视图上操作数组,会改变原数组,
copy 场景
package main import ( "fmt" ) func updateArr(arr [5]int) { arr[0] = 100 fmt.Println("修改后的arr:", arr) } func main() { arr3 := [...]int{2, 4, 5, 6, 7} fmt.Println("原来的:", arr3) updateArr(arr3) fmt.Println("再次查看原始的:", arr3) }
输出结果:
原来的: [2 4 5 6 7]
修改后的arr: [100 4 5 6 7]
再次查看原始的: [2 4 5 6 7]
如上代码可以看到,我们在 updateArr 里面修改了下标为 0 的值,但是我们输出原始数组的时候,并没有变。这就是对数组 copy。
view 场景
func updateArr(arr []int) { arr[0] = 100 fmt.Println("修改后的arr:", arr) } func main() { arr3 := [...]int{2, 4, 5, 6, 7} fmt.Println("原来的:", arr3) // 使用切片 updateArr(arr3[:]) fmt.Println("再次查看原始的:", arr3) }
输出结果:
原来的: [2 4 5 6 7]
修改后的arr: [100 4 5 6 7]
再次查看原始的: [100 4 5 6 7]
为什么 view 能够改变原数组
虽然 Slice 本身是值类型,但是它内部使用了对数组的指针引用,所以修改切片数据,会将数组原有数据修改掉。
当然,在理解上面的同时,一定要知道 go 是如何定义一个切片的
var b []int
所以,在 updateArr 这个函数传参的时候 arr []int 是传切片进去。不然会报错。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。