数组和切片作为函参传递的不同

先说结论(这里以int为例):
  []int会作为切片按地址进行传递
  [3]int会作为数组按值传递

Golang代码实例

package main

import "fmt"

func main(){
  a:=[]int{1,2,3}
  modifySlice(a)
  fmt.Println("main()中 a:",a)
}

func modifySlice(a []int){
  a[0]=100
  fmt.Println("对切片进行modifySlice()之后 a:",a)
}
输出结果
对切片进行modifySlice()之后 a: [100 2 3]
main()中 a: [100 2 3]
package main

import "fmt"

func main() {
	a := [3]int{1, 2, 3}
	modifyArr(a)
	fmt.Println("main()中 a:", a)
}

func modifyArr(a [3]int) {
	a[0] = 100
	fmt.Println("对切片进行modifyArr()之后 a:", a)
}
输出结果
对数组进行modifyArr()之后 a: [100 2 3]
main()中 a: [1 2 3]

解决了这个问题之后,又遇到一个奇怪的问题,花了一点时间找到了问题所在,现在贴出来供参考:

当函数要返回经过操作之后的slice时,返回的slice的地址发生了改变,不再是传入的地址,代码如下

package main

import (
  "fmt"
  "unsafe"
  )

func main(){
  a:=[]int{1,2,3}
  b:=modifySlice(a)
  fmt.Println(&a==&b)
  fmt.Println("作为参数的a的地址:",unsafe.Pointer(&a))
  fmt.Println("modifySlice返回的a的地址:",unsafe.Pointer(&b))

}

func modifySlice(a []int) []int{
  a[0]=100
  return a
}
输出结果
false
作为参数的a的地址: 0x115520e0
modifySlice返回的a的地址: 0x115520f0
Golang数组切片是两种不同的数据类型,用于存储相同数据类型的容器。数组的长度是固定的,而切片的长度是可变的。在日常应用中,切片的使用更为普遍。 数组在声明时需要指定长度,并且在初始化时必须提供相同长度的元素。例如,`a := int{1, 2, 3}`就是一个长度为3的整数数组数组的长度一旦确定后就不能更改。 切片是基于数组的引用类型。它不需要指定固定的长度,并且可以根据需要动态扩展或缩小。切片包装着底层数组,通过指定起始索引和结束索引来指定子集。例如,`b := a[:]`就是一个切片,它包含了数组a的所有元素。 数组适用于需要固定长度的场景,而切片适用于长度可变的情况。在实际应用中,切片更常用,因为它提供了更大的灵活性和便利性。 总结: - 数组是长度固定的容器,切片是长度可变的容器; - 数组在声明时需要指定长度,切片则不需要; - 数组的长度一旦确定后就不能更改,而切片可以根据需要动态扩展或缩小; - 切片是基于数组的引用类型,可以通过指定起始索引和结束索引来指定子集。 参考资料: Golang中的「数组」和「切片」都是存储同一数据类型的容器,只不过Golang中的数组长度是固定的,而切片的长度是可变化的。 切片是引用类型,切片包装的数组称为该切片的底层数组。我们来看一段代码://a是一个数组,注意数组是一个固定长度的,初始化时候必须要指定长度,不指定长度的话就是切片了 a := int{1, 2, 3} //b是数组,是a...。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蝉沐风的码场

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值