主頁(yè) > 知識(shí)庫(kù) > 深入解析Go語(yǔ)言編程中slice切片結(jié)構(gòu)

深入解析Go語(yǔ)言編程中slice切片結(jié)構(gòu)

熱門標(biāo)簽:電梯外呼訪客系統(tǒng) 谷歌便利店地圖標(biāo)注 成都呼叫中心外呼系統(tǒng)平臺(tái) 騰訊外呼系統(tǒng)價(jià)格 最短的地圖標(biāo)注 浙江人工智能外呼管理系統(tǒng) ?兓? 百度地圖標(biāo)注搜索關(guān)鍵詞 電銷機(jī)器人可以補(bǔ)救房產(chǎn)中介嗎

數(shù)組轉(zhuǎn)換成切片

復(fù)制代碼 代碼如下:

a := [10]int{}
fmt.Println(a)
 s1 := a[:10]  //取前10個(gè)元素 [5:]取 5-最后的元素
 fmt.Println(s1)

slice測(cè)試
復(fù)制代碼 代碼如下:

a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'h'}
sa := a[2:5]
fmt.Println(string(sa))
sd1 := a[3:5]
fmt.Println(string(sd1)) //看看效果

我們看到這樣的是slice_a指向Array_ori 其實(shí)是從c指向到k 我們用fmt.Println(cap(slice_a)) 結(jié)果肯定不是3

自己動(dòng)手試一下下邊這個(gè)
 

復(fù)制代碼 代碼如下:
  
        a := []byte{'a', 'b', 'c', 'd', 'e', 'f', 'h'}
 sa := a[2:5]
fmt.Println(string(sa))
 s := sa[1:3]
 fmt.Println(string(s))
 s2 := sa[3:5]
 fmt.Println(string(s2))

slice是指向底層的數(shù)組,如果多個(gè)slice指向同一個(gè)的時(shí)候,其中一個(gè)改變了,其他的都改變。試一下下邊這個(gè)
 
復(fù)制代碼 代碼如下:

a := []int{1, 2, 3, 4, 5}
s1 := a[2:5]
s2 := a[1:3]
fmt.Println(s1, s2)
s1[0] = 9
fmt.Println(s1, s2)

切片是引用類型,即如果賦值切片給另一個(gè)切片,它們都指向同一底層數(shù)組。例如,如果某函數(shù)取切片參量,對(duì)其元素的改動(dòng)會(huì)顯現(xiàn)在調(diào)用者中,類似于傳遞一個(gè)底層數(shù)組的指針。因此 Read 函數(shù)可以接受切片參量,而不需指針和計(jì)數(shù);切片的長(zhǎng)度決定了可讀數(shù)據(jù)的上限。這里是 os 包的 File 型的 Read 方法的簽名:

復(fù)制代碼 代碼如下:

  func (file *File) Read(buf []byte) (n int, err os.Error)

此方法返回讀入字節(jié)數(shù)和可能的錯(cuò)誤值。要讀入一個(gè)大的緩沖 b 的首32字節(jié), 切片(動(dòng)詞)緩沖。
復(fù)制代碼 代碼如下:

      n, err := f.Read(buf[0:32])

這種切片常用且高效。實(shí)際上,先不管效率,此片段也可讀緩沖的首32字節(jié)。
復(fù)制代碼 代碼如下:

      var n int
      var err os.Error
      for i := 0; i 32; i++ {
          nbytes, e := f.Read(buf[i:i+1])  // Read one byte.
          if nbytes == 0 || e != nil {
              err = e
              break
          }
          n += nbytes
      }

只要還在底層數(shù)組的限制內(nèi),切片的長(zhǎng)度可以改變,只需賦值自己。切片的容量,可用內(nèi)部函數(shù) cap 取得,給出此切片可用的最大長(zhǎng)度。下面的函數(shù)給切片添值。如果數(shù)據(jù)超過(guò)容量,切片重新分配,返回結(jié)果切片。此函數(shù)利用了 len 和 cap 對(duì) nil 切片合法、返回0的事實(shí)。


Apppend的用法
 

復(fù)制代碼 代碼如下:

a := make([]int, 3, 6)
 fmt.Printf("%p", a)
 a = append(a, 1, 2, 3)
 fmt.Printf("%v %p\n", a, a)
 a = append(a, 1, 2, 3)
 fmt.Printf("%v %p\n", a, a)

我們必須返回切片,因?yàn)楸M管 Append 可以改變 slice 的元素, 切片自身(持有指針、長(zhǎng)度和容量的運(yùn)行態(tài)數(shù)據(jù)結(jié)構(gòu))是值傳遞的。添加切片的主意很有用,因此由內(nèi)置函數(shù) append 實(shí)現(xiàn)。
復(fù)制代碼 代碼如下:

  func Append(slice, data[]byte) []byte {
      l := len(slice)
      if l + len(data) > cap(slice) {  // reallocate
          // Allocate double what's needed, for future growth.
          newSlice := make([]byte, (l+len(data))*2)
          // Copy data (could use bytes.Copy()).
          for i, c := range slice {
              newSlice[i] = c
          }
          slice = newSlice
      }
      slice = slice[0:l+len(data)]
      for i, c := range data {
          slice[l+i] = c
      }
      return slice
  }

當(dāng)slice中append追加的元素超過(guò)了指向的容量,就會(huì)重新指向一個(gè)新的底層數(shù)組,所以一個(gè)底層數(shù)組的改變,不會(huì)帶動(dòng)其他的改變,試一下下邊的代碼

復(fù)制代碼 代碼如下:

a := []int{1, 2, 3, 4, 5}
s1 := a[2:5]
s2 := a[1:3]
fmt.Println(s1, s2)
s2 = append(s2, 1, 2, 2, 3, 3, 4, 5)
s1[0] = 9
fmt.Println(s1, s2)

copy
這是一個(gè)拷貝的函數(shù),下邊的代碼是從s2拷貝到s1然后我們會(huì)看到結(jié)果是[7 8 9 4 5]
如果是copy(s2,s1) 我們看到的結(jié)果是[1 2 3]
 
復(fù)制代碼 代碼如下:

s1 := []int{1, 2, 3, 4, 5}
s2 := []int{7, 8, 9}
copy(s1, s2)
fmt.Println(s1)

您可能感興趣的文章:
  • Go語(yǔ)言--切片(Slice)詳解

標(biāo)簽:七臺(tái)河 眉山 紹興 邢臺(tái) 雅安 上海 盤錦 宜昌

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《深入解析Go語(yǔ)言編程中slice切片結(jié)構(gòu)》,本文關(guān)鍵詞  深入,解析,語(yǔ)言編程,中,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《深入解析Go語(yǔ)言編程中slice切片結(jié)構(gòu)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于深入解析Go語(yǔ)言編程中slice切片結(jié)構(gòu)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章