Go語言在聲明變量的時候,會自動對變量對應的內存區(qū)域進行初始化操作。每個變量會被初始化成其類型的默認值,例如: 整型和浮點型變量的默認值為0。 字符串變量的默認值為空字符串。 布爾型變量默認為false。 切片、函數、指針變量的默認為nil。
func main() {
var s1 []int // nil切片
s2 := make([]int,0) // 空切片
s4 := make([]int,0) // 空切片
s5 := []int{} // 空切片
}
直接看代碼,不同聲明方式:使用 make() 函數生成的切片一定發(fā)生了內存分配操作,但給定開始與結束位置(包括切片復位)的切片只是將新的切片結構指向已經分配好的內存區(qū)域,設定開始與結束位置,不會發(fā)生內存分配操作。這里的內存分配我理解的就是引用數組指針地址
- nil切片和空切片指向的地址不一樣。nil空切片引用數組指針地址為0(無指向任何實際地址)
- 空切片的引用數組指針地址是有的,且固定為一個值
我們看看切片的數據結構:
type SliceHeader struct {
Data uintptr //引用數組指針地址
Len int // 切片的目前使用長度
Cap int // 切片的容量
}
nil切片和空切片最大的區(qū)別在于指向的數組引用地址是不一樣的。
![](http://img.jbzj.com/file_images/article/202103/202132694837477.png?20212269493)
所有的空切片指向的數組引用地址都是一樣的
![](http://img.jbzj.com/file_images/article/202103/202132694914442.png?202122694926)
示例
package main
import "fmt"
func main(){
var a []int
b:=make([]int,0)
if a==nil{
fmt.Println("a is nil")
}else{
fmt.Println("a is not nil")
}
if b==nil{
fmt.Println("b is nil")
}else{
fmt.Println("b is not nil")
}
}
運行結果:
a is nil
b is not nil
Process finished with exit code 0
因此:
通過var a []int創(chuàng)建的切片是一個nil切片
通過b:=make([]int,0)創(chuàng)建的是一個空切片,(底層數組為空,但底層數組指針非空)
到此這篇關于Go中的nil切片和空切片區(qū)別詳解的文章就介紹到這了,更多相關Go nil切片和空切片內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- GO語言數組和切片實例詳解
- Go語言實現字符串切片賦值的方法小結
- Golang中切片的用法與本質詳解
- 深入解析Go語言編程中slice切片結構
- 深入理解Go語言中的數組和切片
- 淺談golang slice 切片原理
- Go語言中切片使用的注意事項小結
- 如何在Go中使用切片容量和長度
- golang常用手冊之切片(Slice)原理
- go切片的copy和view的使用方法