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

golang切片內(nèi)存應(yīng)用技巧詳解

 更新時(shí)間:2019年12月04日 10:51:01   作者:kevinyan  
這篇文章主要介紹了golang切片內(nèi)存應(yīng)用技巧詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

在 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/wiki/SliceTricks#filtering-without-allocating

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 實(shí)用的Go語(yǔ)言開(kāi)發(fā)工具及使用示例

    實(shí)用的Go語(yǔ)言開(kāi)發(fā)工具及使用示例

    這篇文章主要為大家介紹了實(shí)用的Go語(yǔ)言開(kāi)發(fā)工具及使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 使用client-go工具調(diào)用kubernetes API接口的教程詳解(v1.17版本)

    使用client-go工具調(diào)用kubernetes API接口的教程詳解(v1.17版本)

    這篇文章主要介紹了使用client-go工具調(diào)kubernetes API接口(v1.17版本),本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • 一文詳解golang通過(guò)io包進(jìn)行文件讀寫

    一文詳解golang通過(guò)io包進(jìn)行文件讀寫

    這篇文章主要介紹了golang通過(guò)io包進(jìn)行文件讀寫文中有詳細(xì)的代碼示例。對(duì)學(xué)習(xí)或工資有很好的幫助,需要的小伙伴可以參考閱讀一下
    2023-04-04
  • 基于Go語(yǔ)言構(gòu)建RESTful API服務(wù)

    基于Go語(yǔ)言構(gòu)建RESTful API服務(wù)

    在實(shí)際開(kāi)發(fā)項(xiàng)目中,你編寫的服務(wù)可以被其他服務(wù)使用,這樣就組成了微服務(wù)的架構(gòu);也可以被前端調(diào)用,這樣就可以前后端分離。那么,本文主要介紹什么是 RESTful API,以及 Go 語(yǔ)言是如何玩轉(zhuǎn) RESTful API 的
    2021-07-07
  • go語(yǔ)言獲取系統(tǒng)盤符的方法

    go語(yǔ)言獲取系統(tǒng)盤符的方法

    這篇文章主要介紹了go語(yǔ)言獲取系統(tǒng)盤符的方法,涉及Go語(yǔ)言調(diào)用winapi獲取系統(tǒng)硬件信息的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • 詳解Go語(yǔ)言中for range的

    詳解Go語(yǔ)言中for range的"坑"

    這篇文章主要介紹了詳解Go語(yǔ)言中for range的"坑",文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • Go 語(yǔ)言中的空接口(推薦)

    Go 語(yǔ)言中的空接口(推薦)

    這篇文章主要介紹了Go 語(yǔ)言中的空接口的實(shí)現(xiàn)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • golang關(guān)閉chan通道的方法示例

    golang關(guān)閉chan通道的方法示例

    在go語(yǔ)言中,通道(channel)是一個(gè)非常重要的概念,通道提供了一種在不同 goroutine 之間安全地傳遞數(shù)據(jù)的方式,在本文中,我們將討論如何關(guān)閉通道以及在關(guān)閉通道時(shí)需要考慮的事項(xiàng),需要的朋友可以參考下
    2024-02-02
  • Go語(yǔ)言題解LeetCode455分發(fā)餅干示例詳解

    Go語(yǔ)言題解LeetCode455分發(fā)餅干示例詳解

    這篇文章主要為大家介紹了Go語(yǔ)言題解LeetCode455分發(fā)餅干示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • GO語(yǔ)言實(shí)現(xiàn)文件上傳代碼分享

    GO語(yǔ)言實(shí)現(xiàn)文件上傳代碼分享

    本文給大家分享的是一則使用golang實(shí)現(xiàn)文件上傳的代碼,主要是使用os.Create創(chuàng)建文件,io.Copy來(lái)保存文件,思路非常清晰,這里推薦給大家,有需要的小伙伴參考下吧。
    2015-03-03

最新評(píng)論