欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Golang中的Slice與數(shù)組及區(qū)別詳解

 更新時間:2020年02月26日 08:24:47   作者:alienwu  
數(shù)組是一種具有固定長度的基本數(shù)據(jù)結構,在golang中與C語言一樣數(shù)組一旦創(chuàng)建了它的長度就不允許改變,數(shù)組的空余位置用0填補,不允許數(shù)組越界。今天小編通過實例代碼操作給大家詳細介紹lang中的Slice與數(shù)組的相關知識,一起看看吧

在golang中有數(shù)組和Slice兩種數(shù)據(jù)結構,Slice是基于數(shù)組的實現(xiàn),是長度動態(tài)不固定的數(shù)據(jù)結構,本質上是一個對數(shù)組字序列的引用,提供了對數(shù)組的輕量級訪問。那么我們今天就給大家詳細介紹下Golang中的Slice與數(shù)組,

1.Golang中的數(shù)組

    數(shù)組是一種具有固定長度的基本數(shù)據(jù)結構,在golang中與C語言一樣數(shù)組一旦創(chuàng)建了它的長度就不允許改變,數(shù)組的空余位置用0填補,不允許數(shù)組越界。

     數(shù)組的一些基本操作:

     1.創(chuàng)建數(shù)組:

func main() {
 var arr1 = [...]int{1,2,3,4} //[...]默認為元素的數(shù)量即為數(shù)組的長度
 fmt.Println(len(arr1)) //4
 arr1[4] = 5 //panic 數(shù)組越界
 fmt.Println(arr1)
 var arr2 = [10]int{1,2,3,4}
 fmt.Println(arr2) //[1 2 3 4 0 0 0 0 0 0]
}

  2.數(shù)組是值拷貝傳遞:

func main() {
 var arr = [10]int{4,5,7,11,8,9}
 fmt.Println(arr) //[4,5,7,11,8,9,0,0,0,0]
 //驗證數(shù)組是值拷貝傳遞
 AddOne(arr)
 fmt.Println(arr) //[4,5,7,11,8,9,0,0,0,0]
}
func AddOne(arr [10]int){
 arr[9] = 999999
 fmt.Println(arr) //[4,5,7,11,8,9,0,0,0,999999]
}

2.Golang中的切片(slice) 

     1.首先看看slice的源碼結構:

type slice struct {
 array unsafe.Pointer
 len int
 cap int
}

  slice是一個特殊的引用類型,但是它自身也是個結構體

       屬性len表示可用元素數(shù)量,讀寫操作不能超過這個限制,不然就會panic

       屬性cap表示最大擴張容量,當然這個擴張容量也不是無限的擴張,它是受到了底層數(shù)組array的長度限制,超出了底層array的長度就會panic

     2.slice的創(chuàng)建:

func main() {
  var arr = [...]int{0,1,2,3,4,5,6}
  slice1 := arr[1:4:5] //{low:high:max} 最多再擴張一個元素
  //max超出 len(arr)
  //slice2 := arr[1:4:7] //panic
  fmt.Println(slice1) //[1,2,3]
  slice3 := slice1[1:3:4] //[2,3] 大于4會panic
  fmt.Println(slice3)
}

 上面代碼中創(chuàng)建了一個長度為7的數(shù)組arr,同時創(chuàng)建一個基于數(shù)組arr的切片slice1,切片引用了數(shù)組的index=1到index=3之間的元素,同時也允許切片最大擴張1個元素大小的空間。如果這個擴張空間大于7那么程序就會panic。最后創(chuàng)建了一個基于slice1延申的一個切片slice2,它引用了切片的index=1到index=3之間的元素,由于slice1最大擴容1個元素,因此slice2也最多擴容一個元素,超過了會panic。

    創(chuàng)建基于底層數(shù)組的slice,其cap取值在: len<=cap<=len(arr)之間

    創(chuàng)建基于一個切片的slice,其cap取值在: len(slice1)<=cap<=cap(slice1)之間

   3.slice使用make創(chuàng)建

func main() {
  var slice = make([]int,3,5) //len=3,cap=5
  fmt.Println(slice)  //[0,0,0]
  slice2:=slice[:5]  //slice實現(xiàn)了對slice的擴容,切片長度變?yōu)?
  fmt.Println(slice2) //[0,0,0,0,0]
}

   4.切片作為參數(shù)傳遞

func main() {
  var slice = make([]int,3,5) //len=3,cap=5
  fmt.Println(slice)  //[0,0,0]
  slice2:=slice[:5]  //slice實現(xiàn)了對slice的擴容,切片長度變?yōu)?
  fmt.Println(slice2) //[0,0,0,0,0]
  slice[0] = 999  //這里slice和slice的index=0位置都是999 因為他們引用的底層數(shù)組的index=0位置都是999
  fmt.Println(slice)
  fmt.Println(slice2)
  AddOne(slice) //[8888,0,0]
  fmt.Println(slice) //[8888,0,0]
  fmt.Println(slice2) //[8888,0,0,0]
}
func AddOne(s []int){
 s[0] = 8888
 fmt.Println(s)
}

  因為切片是個引用類型,所以它作為參數(shù)傳遞給函數(shù),函數(shù)操作的實質是底層數(shù)組

3.Golang中的切片追加append()

func main() {
  var arr = [...]int{1,2,3,4}
  fmt.Println(arr) //[1,2,3,4]
  slice := arr[:]
  fmt.Println(slice) //[1,2,3,4]
  slice = append(slice,[]int{5,6,7}...) //此時slice的引用地址已經發(fā)生改變了,它引用的底層數(shù)組再也不是arr了,而是一個新的數(shù)組newarr[1,2,3,4,5,6,7]
  fmt.Println(slice) //[1,2,3,4,5,6,7]
  //驗證slice引用的地址已經發(fā)生改變
  slice[0] = 666
  fmt.Println(arr) //[1,2,3,4]
  fmt.Println(slice) //[666,2,3,4,5,6,7]
}

  這里由于slice進行追加的元素超出了原來數(shù)組的大小,因此go內部會幫我們創(chuàng)建一個新的底層數(shù)組,而slice的引用地址不再是arr了,變成了新創(chuàng)建的數(shù)組。

       還有一種情況就是當slice進行追加的時候沒有超出原來數(shù)組的大小的時候,其引用地址沒有發(fā)生改變。

func main() {
  var arr = [6]int{1,2,3,4}
  fmt.Println(arr) //[1,2,3,4,0,0]
  slice := arr[:4]
  fmt.Println(slice) //[1,2,3,4]
  slice = append(slice,5)
  fmt.Println(arr) //[1,2,3,4,5,0]
  fmt.Println(slice) //[1,2,3,4,5]
}

4.總結

    (1)go是有數(shù)組的,只是平時用切片比較多。數(shù)組大小一旦創(chuàng)建就不能改變,數(shù)組長度大于元素個數(shù)的時候會用0補位,這跟其他語言是相通的。

     (2)切片slice可以看作是對數(shù)組的一切操作,它是一個引用數(shù)據(jù)類型,其數(shù)據(jù)結構包括底層數(shù)組的地址,以及元素可操作長度len或可擴容長度cap。

     (3)要想突破slice的擴容cap限制進行無限擴容就需要使用append()函數(shù)進行操作。如果append追加的元素后slice的總長度不超過底層數(shù)組的總長度,那么slice引用的地址不會發(fā)生改變,反之引用地址會           變成新的數(shù)組的地址。

     (4)slice是一個抽象的概念,它存在的意義在于方便對一個順序結構進行一些方便操作,例如查找,排序,追加等等,這個類似于python的list。

下面看下golang 數(shù)組和slice 的區(qū)別

golang 數(shù)組和切片的區(qū)別

數(shù)組: 長度不可變,初始化的時候聲明長度

slice 長度可變

var a [32] int

var b [3][5] int

a和b的類型不一樣

slice 創(chuàng)建的時候可以不指定長度。

總結

到此這篇關于Golang中的Slice與數(shù)組及區(qū)別詳解的文章就介紹到這了,更多相關golang slice 數(shù)據(jù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Golang使用反射的動態(tài)方法調用詳解

    Golang使用反射的動態(tài)方法調用詳解

    Go是一種靜態(tài)類型的語言,提供了大量的安全性和性能。這篇文章主要和大家介紹一下Golang使用反射的動態(tài)方法調用,感興趣的小伙伴可以了解一下
    2023-03-03
  • Go處理包含多種引號的字符串的幾種方法

    Go處理包含多種引號的字符串的幾種方法

    在Go中,有幾種方式可以處理包含多種引號的字符串,以確保代碼的可讀性和正確性,本文將給大家詳細介紹了這幾種處理方式,并通過代碼示例講解的非常詳細,需要的朋友可以參考下
    2024-04-04
  • Go語言使用AES加密解密的示例代碼

    Go語言使用AES加密解密的示例代碼

    這篇文章主要介紹了Go語言使用AES加密解密的示例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • Golang基礎教程之字符串string實例詳解

    Golang基礎教程之字符串string實例詳解

    這篇文章主要給大家介紹了關于Golang基礎教程之字符串string的相關資料,需要的朋友可以參考下
    2022-07-07
  • Go語言實現(xiàn)LRU算法的核心思想和實現(xiàn)過程

    Go語言實現(xiàn)LRU算法的核心思想和實現(xiàn)過程

    這篇文章主要介紹了Go語言實現(xiàn)LRU算法的核心思想和實現(xiàn)過程,LRU算法是一種常用的緩存淘汰策略,它的核心思想是如果一個數(shù)據(jù)在最近一段時間內沒有被訪問到,那么在將來它被訪問的可能性也很小,因此可以將其淘汰,感興趣想要詳細了解可以參考下文
    2023-05-05
  • 如何使用Go語言實現(xiàn)遠程執(zhí)行命令

    如何使用Go語言實現(xiàn)遠程執(zhí)行命令

    遠程執(zhí)行命令最常用的方法就是利用SSH協(xié)議,將命令發(fā)送到遠程機器上執(zhí)行,并獲取返回結果。本文將介紹如何使用Go語言實現(xiàn)遠程執(zhí)行命令。下面一起來看看。
    2016-08-08
  • Go時間格式化的實現(xiàn)

    Go時間格式化的實現(xiàn)

    本文主要介紹了Go時間格式化的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 淺析Go語言中的緩沖區(qū)及其在fmt包中的應用

    淺析Go語言中的緩沖區(qū)及其在fmt包中的應用

    這篇文章主要為大家詳細介紹了Go語言中的緩沖區(qū)及其在fmt包中的應用的相關知識,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2024-01-01
  • Go語言Http?Server框架實現(xiàn)一個簡單的httpServer

    Go語言Http?Server框架實現(xiàn)一個簡單的httpServer

    這篇文章主要為大家介紹了Go語言Http?Server框架實現(xiàn)一個簡單的httpServer抽象,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • 淺談Golang 切片(slice)擴容機制的原理

    淺談Golang 切片(slice)擴容機制的原理

    我們知道 Golang 切片在容量不足的情況下會進行擴容,擴容的原理是怎樣的呢,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評論