主頁(yè) > 知識(shí)庫(kù) > golang切片反序?qū)嵗?/div>

golang切片反序?qū)嵗?/h1>

熱門標(biāo)簽:官渡電銷外呼管理系統(tǒng)怎么收費(fèi) 谷歌美發(fā)店地圖標(biāo)注 杭州人工智能電銷機(jī)器人費(fèi)用 利用地圖標(biāo)注位置 貴州電話智能外呼系統(tǒng) 400開(kāi)頭電話怎樣申請(qǐng) 赤峰電銷 江蘇呼叫中心外呼系統(tǒng)有效果嗎 地圖區(qū)域圖標(biāo)注后導(dǎo)出

看代碼吧~

package main
import (
 "fmt"
)
func main() {
 fmt.Println(reverse([]byte{11,22,33,44}))
}
func reverse(s []byte) []byte {
 for i, j := 0, len(s)-1; i  j; i, j = i+1, j-1 {
 s[i], s[j] = s[j], s[i]
 }
 return s
}

補(bǔ)充:golang切片內(nèi)存應(yīng)用技巧

在 Go 語(yǔ)言中切片是使用非常頻繁的一種聚合類型,它代表變長(zhǎng)的序列,底層引用一個(gè)數(shù)組對(duì)象。

一個(gè)切片由三個(gè)部分構(gòu)成:指針、長(zhǎng)度和容量。

指針指向該切片自己第一個(gè)元素對(duì)應(yīng)的底層數(shù)組元素的內(nèi)存地址。

切片的類型聲明如下:

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

多個(gè)切片之間可以共享底層數(shù)組的數(shù)據(jù),并且引用的數(shù)組區(qū)間可能重疊。利用切片 的這個(gè)特性我們可以在原有內(nèi)存空間中對(duì)切片進(jìn)行反轉(zhuǎn)、篩選和去重等操作,這樣就不用聲明一個(gè)指向新內(nèi)存的切片來(lái)存儲(chǔ)結(jié)果,從而節(jié)省了內(nèi)存空間以及擴(kuò)展底層數(shù)組的消耗,這在切片長(zhǎng)度足夠大時(shí)效果就會(huì)非常顯著。

下面這些例子都是在切片底層數(shù)組的內(nèi)存空間上進(jìn)行的操作,需要注意的是這些操作在底層數(shù)組上生成新切片的同時(shí)也會(huì)更改底層數(shù)組。

刪除指定位置的元素

下面的函數(shù)從原切片中刪除索引位置i上的元素

func remove(slice []int, i int) []int {
  copy(slice[i:], slice[i+1:])
  return slice[:len(slice)-1]
}
 
func main() {
  s := []int{5, 6, 7, 8, 9}
  fmt.Println(remove(s, 2)) // "[5 6 8 9]"
}

內(nèi)置的copy函數(shù)可以方便地將一個(gè)切片復(fù)制另一個(gè)相同類型的切片上。

篩選元素

下面的函數(shù)從輸入的源切片中篩選出滿足條件的切片元素,返回一個(gè)滿足條件的元素組成的新切片。

type funcType func(T) bool //代表篩選邏輯函數(shù),可以按需實(shí)現(xiàn)
 
func filter(a []T, f funcType) []T {
  b := a[:0]
  for _, x := range a {
    if f(x) { 
      b = append(b, x)
    }
  }
  return b
}

反轉(zhuǎn)切片

func reverse(a []T) []T {
  for i := len(a)/2-1; i >= 0; i-- {
    opp := len(a)-1-i
    a[i], a[opp] = a[opp], a[i]
  }    
  return a
}

分組切片

下面的函數(shù)接收一個(gè)[]int 類型的源切片actions, 返回一個(gè)按指定長(zhǎng)度分組的嵌套切片(解釋起來(lái)好難,用過(guò)PHP 的同學(xué)可以理解為 Go 版本的array_chunk 函數(shù),沒(méi)用過(guò)的看下面例子)。

假設(shè)切面值為:[]int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9},設(shè)置分組中元素長(zhǎng)度batchSize為3,函數(shù)調(diào)用后返回的分組后的切片為[[0 1 2] [3 4 5] [6 7 8] [9]]

func chunk(actions []int, batchSize int) []int {
  var batches [][]int
 
  for batchSize  len(actions) {
    actions, batches = actions[batchSize:], append(batches, actions[0:batchSize:batchSize])
  }
  batches = append(batches, actions)    
  return batches
}
 
func main() {
  actions := []int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
  batchSize := 3
  chunks = chunk(actions, batchSize)
  //chunks 為[[0 1 2] [3 4 5] [6 7 8] [9]]
}

這里順便說(shuō)一下,完整的切片表達(dá)式形式如下:

input[low:high:max]

最后一個(gè) max 的作用是,生成的切片的cap(容量)為max - low。

原地去重(只針對(duì)可比較的切片類型)

import "sort"
 
func main() {
  in := []int{3,2,1,4,3,2,1,4,1} // any item can be sorted
  sort.Ints(in)
  j := 0
  for i := 1; i  len(in); i++ {
    if in[j] == in[i] {
      continue
    }
    j++
 
    in[j] = in[i]
  }
  result := in[:j+1]
  fmt.Println(result) // [1 2 3 4] 
}

文章中部分例子來(lái)自golang 官方的 GitHub 的 wiki ,在這個(gè) wiki 里介紹了很多的切片使用技巧,了解更多可以訪問(wèn)golang 的 GitHub Wiki https://github.com/golang/go/...

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Golang二維切片初始化的實(shí)現(xiàn)
  • golang切片擴(kuò)容規(guī)則實(shí)現(xiàn)
  • golang修改結(jié)構(gòu)體中的切片值方法
  • golang 切片截取參數(shù)方法詳解
  • golang 字符串切片去重實(shí)例
  • golang將切片或數(shù)組根據(jù)某個(gè)字段進(jìn)行分組操作
  • golang 刪除切片的某個(gè)元素及剔除切片內(nèi)的零值方式

標(biāo)簽:松原 河池 鷹潭 黔西 宜春 泰安 武漢 保定

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《golang切片反序?qū)嵗?,本文關(guān)鍵詞  golang,切片,反序,實(shí)例,golang,;如發(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)文章
  • 下面列出與本文章《golang切片反序?qū)嵗废嚓P(guān)的同類信息!
  • 本頁(yè)收集關(guān)于golang切片反序?qū)嵗南嚓P(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章