时间:2021-05-22
我比较喜欢先给出代码,然后得出结论
数组
复制代码 代码如下:
package main
import (
"fmt"
)
func main() {
arr := [...]int{1, 2, 3}
//打印初始的指针
fmt.Printf("the pointer is : %p \n", &arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", &any)
}
结果
复制代码 代码如下:
1 the pointer is : 0xc082008580
2 the pointer is : 0xc0820001d0
切片
复制代码 代码如下:
package main
import (
"fmt"
)
func main() {
arr := make([]int, 3)
//打印初始的指针
fmt.Printf("the pointer is : %p \n", arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
}
结果
复制代码 代码如下:
1 the pointer is : 0xc082008580
2 the pointer is : 0xc082008580
map
复制代码 代码如下:
package main
import (
"fmt"
)
func main() {
arr := make(map[int]string)
//arr := [3]int{1, 2, 3}
//打印初始的指针
fmt.Printf("the pointer is : %p \n", arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
}
运行结果
复制代码 代码如下:
1 the pointer is : 0xc082007c80
2 the pointer is : 0xc082007c80
由此,我们看到数组本身传过去的是值,传到函数之后,被开辟了另外一个空间。
因为数组就是他本身。这一句好像不太好理解。
这是切片 arr := make([]int, 3) 而arr 本身不是一个数组,至少不是我们所想要的指向的一个数组。只是arr里有一个地址指向数组。
这么举个例子:
arr := [...]int{1,2,3,4,5} 这是一个数组,懂得go语言的都明白。 arr本身就是数组
arrSlice := arr[0:5] 这是一个切片。 打印所得的值是一样的,和上面。 arrSlice本身不是数组,只是arrSlice本身有一个值是指向arr的指针。
切片是指一个结构体,大体结构像这样:
复制代码 代码如下:
struct slice{
ptr *Elem
len int
cap int
}
也就是说,上面的arrSlice其实是一个结构体。里面有一个属性 ptr指向数组 arr
其实arrSlice也是传到函数里,也是进行了复制。但是尽管传过去是一个复制的结构体,他的属性ptr,没有变。还是一个指向原数组的指针。
下面的例子见证他自己传过去,是一个复制的过程:
复制代码 代码如下:
package main
import (
"fmt"
)
func main() {
arrSlice := make([]int, 4)
fmt.Printf("the pointer is : %p \n", arrSlice)
fmt.Printf("the pointer is : %p \n", &arrSlice) //这是arrSlice本身的指针,也就是结构体的指针
printPointer(arrSlice)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
fmt.Printf("the pointer is : %p \n", &any) //打印传过来的结构体arrSlice的指针
}
看结果:
复制代码 代码如下:
the pointer is : 0xc0820085a0
the pointer is : 0xc082008580
the pointer is : 0xc0820085a0
the pointer is : 0xc0820001d0
第1、3个的打印是打印这个结构体的ptr属性,也就是指向数组的指针。
其实这个结构体传到函数里,是一个复制的过程,第2、4的指针不一样。
大家在对照下面的图片理解一下:
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
golang复合类型包括:结构体、数组、切片、Maps。1、数组数组golang中的数组与C语言中的数组差异很大,倒更类似Pascal中的数组。(Slice,下
golang中range在slice和map遍历中的注意事项packagemainimport("fmt")funcmain(){slice:=[]int{0,
最近做个练习,用到Array.slice()和Array.splice(),以前没有注意其返回值类型Array.slice()返回Array--一个由原始数组中
数组:复制传递(不要按照c/c++的方式去理解,c/c++中数组是引用传递),定长切片:引用传递,底层实现是3个字段array(数组)+len(长度)+cap(
Go语言切片(Slice)Go语言切片是对数组的抽象。Go数组的长度不可改变,在特定场景中这样的集合就不太适用,Go中提供了一种灵活,功能强悍的内置类型切片("