最近项目中有遇到类似问题,做个记录。
举个例子,[5]int为数组,[]int为slice(数组切片),数组是值类型,而slice为引用类型,值类型作为参数传入函数,只是拷贝了个副本,修改并不会作用到传入的那个参数,所以一般使用slice作为参数,免去了拷贝的消耗,但是有坑在里面,下面写例子说明。
1.slice作为参数
package main import "fmt" type DbItem struct { Id int16 Cnt int32 } func combineItem(itemList []DbItem,id int16,cnt int32) { item := DbItem{Id: int16(id),Cnt: int32(cnt)} itemList[0] = item fmt.Printf("combineItem itemList values: %v \n",itemList) } func main() { itemList := make([]DbItem,5) combineItem(itemList,int16(1),int32(2)) fmt.Printf("main itemList values: %v \n",itemList) }
运行结果如下:
combineItem itemList values: [{1 2} {0 0} {0 0} {0 0} {0 0}]
main itemList values: [{1 2} {0 0} {0 0} {0 0} {0 0}]
2.数组作为参数。
package main import "fmt" type DbItem struct { Id int16 Cnt int32 } func combineItem(itemList [5]DbItem,Cnt: int32(cnt)} itemList[1] = item fmt.Printf("combineItem itemList values: %v \n",itemList) } func main() { itemList := [5]DbItem{{Id: 3,Cnt: 4}} combineItem(itemList,itemList) }
运行结果如下:
combineItem itemList values: [{3 4} {1 2} {0 0} {0 0} {0 0}]
main itemList values: [{3 4} {0 0} {0 0} {0 0} {0 0}]
3.特别要注意,如果函数内使用了append,千万不要把参数当引用来用,会出问题。
package main import "fmt" type DbItem struct { Id int16 Cnt int32 } func combineItem(itemList []DbItem,cnt int32) { item := DbItem{Id: int16(id),Cnt: int32(cnt)} itemList = append(itemList,item) fmt.Printf("combineItem itemList values: %v \n",itemList) } func main() { itemList := make([]DbItem,5) combineItem(itemList,int32(2)) fmt.Printf("main itemList values: %v \n",itemList) }
运行结果如下:
combineItem itemList values: [{0 0} {0 0} {0 0} {0 0} {0 0} {1 2}]
main itemList values: [{0 0} {0 0} {0 0} {0 0} {0 0}]