亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Golang slice切片操作之切片的追加、刪除、插入等

 更新時間:2017年11月08日 17:15:33   作者:dajianshi  
這篇文章主要介紹了Golang slice切片操作之切片的追加、刪除、插入等,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

本文介紹了Golang slice切片操作之切片的追加、刪除、插入等,分享給大家,具體如下:

一、一般操作

1,聲明變量,go自動初始化為nil,長度:0,地址:0,nil

func main(){
  var ss []string;
  fmt.Printf("length:%v \taddr:%p \tisnil:%v",len(ss),ss, ss==nil)  
}

---
Running...

length:0   addr:0x0   isnil:true
Success: process exited with code 0.

2,切片的追加,刪除,插入操作

func main(){
  var ss []string;
  fmt.Printf("[ local print ]\t:\t length:%v\taddr:%p\tisnil:%v\n",len(ss),ss, ss==nil)  
  print("func print",ss)
  //切片尾部追加元素append elemnt
  for i:=0;i<10;i++{
    ss=append(ss,fmt.Sprintf("s%d",i));
  }
  fmt.Printf("[ local print ]\t:\tlength:%v\taddr:%p\tisnil:%v\n",len(ss),ss, ss==nil)  
  print("after append",ss)
  //刪除切片元素remove element at index
  index:=5;
  ss=append(ss[:index],ss[index+1:]...)
  print("after delete",ss)
  //在切片中間插入元素insert element at index;
  //注意:保存后部剩余元素,必須新建一個臨時切片
  rear:=append([]string{},ss[index:]...) 
  ss=append(ss[0:index],"inserted")
  ss=append(ss,rear...)
  print("after insert",ss)
}
func print(msg string,ss []string){
  fmt.Printf("[ %20s ]\t:\tlength:%v\taddr:%p\tisnil:%v\tcontent:%v",msg,len(ss),ss, ss==nil,ss)  
  fmt.Println()
}
------
Running...

[ local print ]  :   length:0  addr:0x0  isnil:true
[      func print ]  :  length:0  addr:0x0  isnil:true  content:[]
[ local print ]  :  length:10  addr:0xc208056000  isnil:false
[     after append ]  :  length:10  addr:0xc208056000  isnil:false  content:[s0 s1 s2 s3 s4 s5 s6 s7 s8 s9]
[     after delete ]  :  length:9  addr:0xc208056000  isnil:false  content:[s0 s1 s2 s3 s4 s6 s7 s8 s9]
[     after insert ]  :  length:10  addr:0xc208056000  isnil:false  content:[s0 s1 s2 s3 s4 inserted s6 s7 s8 s9]

Success: process exited with code 0.

3,copy的使用。

在使用copy復(fù)制切片之前,要保證目標切片有足夠的大小,注意是大小,而不是容量,還是看例子:

func main() {
  var sa = make ([]string,0);
  for i:=0;i<10;i++{
    sa=append(sa,fmt.Sprintf("%v",i))
    
  }
  var da =make([]string,0,10);
  var cc=0;
  cc= copy(da,sa);
  fmt.Printf("copy to da(len=%d)\t%v\n",len(da),da)
  da = make([]string,5)
  cc=copy(da,sa);
  fmt.Printf("copy to da(len=%d)\tcopied=%d\t%v\n",len(da),cc,da)
   da = make([]string,10)
  cc =copy(da,sa);
  fmt.Printf("copy to da(len=%d)\tcopied=%d\t%v\n",len(da),cc,da)
  
}

---
Running...

copy to da(len=0)  []
copy to da(len=5)  copied=5  [0 1 2 3 4]
copy to da(len=10)  copied=10  [0 1 2 3 4 5 6 7 8 9]

從上面運行結(jié)果,明顯看出,目標切片大小0,容量10,copy不能復(fù)制。目標切片大小小于源切片大小,copy就按照目標切片大小復(fù)制,不會報錯。

二、初始大小和容量

當我們使用make初始化切片的時候,必須給出size。go語言的書上一般都會告訴我們,當切片有足夠大小的時候,append操作是非??斓?。但是當給出初始大小后,我們得到的實際上是一個含有這個size數(shù)量切片類型的空元素,看例子:

func main(){
  var ss=make([]string,10);
  ss=append(ss,"last");
  print("after append",ss)
  
}
---
Running...

[     after append ]  :  length:11  addr:0xc20804c000  isnil:false  content:[     last]

實際上,此時我們應(yīng)該先用下標為切片元素負值。但是如果我們既想有好的效率,有想繼續(xù)使用append函數(shù)而不想?yún)^(qū)分是否有空的元素,此時就要請出make的第三個參數(shù),容量,也就是我們通過傳遞給make,0的大小和足夠大的容量數(shù)值就行了。

func main(){
  var ss=make([]string,0,10);
  ss=append(ss,"last");
  print("after append",ss)
  
}

---
Running...

[     after append ]  :  length:1  addr:0xc20804a000  isnil:false  content:[last]

三、切片的指針。

1,當我們用append追加元素到切片時,如果容量不夠,go就會創(chuàng)建一個新的切片變量,看下面程序的執(zhí)行結(jié)果:

func main() {
  var sa []string
fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
  for i:=0;i<10;i++{
    sa=append(sa,fmt.Sprintf("%v",i))
    fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
  }
  fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);

}

---
Running ...
addr:0x0     len:0 content:[]
addr:0x1030e0c8     len:1 content:[0]
addr:0x10328120     len:2 content:[0 1]
addr:0x10322180     len:3 content:[0 1 2]
addr:0x10322180     len:4 content:[0 1 2 3]
addr:0x10342080     len:5 content:[0 1 2 3 4]
addr:0x10342080     len:6 content:[0 1 2 3 4 5]
addr:0x10342080     len:7 content:[0 1 2 3 4 5 6]
addr:0x10342080     len:8 content:[0 1 2 3 4 5 6 7]
addr:0x10324a00     len:9 content:[0 1 2 3 4 5 6 7 8]
addr:0x10324a00     len:10 content:[0 1 2 3 4 5 6 7 8 9]
addr:0x10324a00     len:10 content:[0 1 2 3 4 5 6 7 8 9]

//很明顯,切片的地址經(jīng)過了數(shù)次改變。

2,如果,在make初始化切片的時候給出了足夠的容量,append操作不會創(chuàng)建新的切片:

func main() {
  var sa = make ([]string,0,10);
fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
  for i:=0;i<10;i++{
    sa=append(sa,fmt.Sprintf("%v",i))
    fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);
  }
  fmt.Printf("addr:%p \t\tlen:%v content:%v\n",sa,len(sa),sa);

}
addr:0x10304140     len:0 content:[]
addr:0x10304140     len:1 content:[0]
addr:0x10304140     len:2 content:[0 1]
addr:0x10304140     len:3 content:[0 1 2]
addr:0x10304140     len:4 content:[0 1 2 3]
addr:0x10304140     len:5 content:[0 1 2 3 4]
addr:0x10304140     len:6 content:[0 1 2 3 4 5]
addr:0x10304140     len:7 content:[0 1 2 3 4 5 6]
addr:0x10304140     len:8 content:[0 1 2 3 4 5 6 7]
addr:0x10304140     len:9 content:[0 1 2 3 4 5 6 7 8]
addr:0x10304140     len:10 content:[0 1 2 3 4 5 6 7 8 9]
addr:0x10304140     len:10 content:[0 1 2 3 4 5 6 7 8 9]

//可見,切片的地址一直保持不變

3, 如果不能準確預(yù)估切片的大小,又不想改變變量(如:為了共享數(shù)據(jù)的改變),這時候就要請出指針來幫忙了,下面程序中,sa就是osa這個切片的指針,我們共享切片數(shù)據(jù)和操作切片的時候都使用這個切片地址就ok了,其本質(zhì)上是:append操作亦然會在需要的時候構(gòu)造新的切片,不過是將地址都保存到了sa中,因此我們通過該指針始終可以訪問到真正的數(shù)據(jù)。

func main() {
  var osa = make ([]string,0);
  sa:=&osa;
  for i:=0;i<10;i++{
    *sa=append(*sa,fmt.Sprintf("%v",i))
    fmt.Printf("addr of osa:%p,\taddr:%p \t content:%v\n",osa,sa,sa);
  }
  fmt.Printf("addr of osa:%p,\taddr:%p \t content:%v\n",osa,sa,sa);
  
}

---
Running...

addr of osa:0xc20800a220,  addr:0xc20801e020   content:&[0]
addr of osa:0xc20801e0a0,  addr:0xc20801e020   content:&[0 1]
addr of osa:0xc20803e0c0,  addr:0xc20801e020   content:&[0 1 2]
addr of osa:0xc20803e0c0,  addr:0xc20801e020   content:&[0 1 2 3]
addr of osa:0xc208050080,  addr:0xc20801e020   content:&[0 1 2 3 4]
addr of osa:0xc208050080,  addr:0xc20801e020   content:&[0 1 2 3 4 5]
addr of osa:0xc208050080,  addr:0xc20801e020   content:&[0 1 2 3 4 5 6]
addr of osa:0xc208050080,  addr:0xc20801e020   content:&[0 1 2 3 4 5 6 7]
addr of osa:0xc208052000,  addr:0xc20801e020   content:&[0 1 2 3 4 5 6 7 8]
addr of osa:0xc208052000,  addr:0xc20801e020   content:&[0 1 2 3 4 5 6 7 8 9]
addr of osa:0xc208052000,  addr:0xc20801e020   content:&[0 1 2 3 4 5 6 7 8 9]

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

相關(guān)文章

  • go語言中值類型和指針類型的深入理解

    go語言中值類型和指針類型的深入理解

    這篇文章主要給大家介紹了關(guān)于go語言中值類型和指針類型的相關(guān)資料,文中通過實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-03-03
  • Golang模擬令牌桶進行對訪問的限流方式

    Golang模擬令牌桶進行對訪問的限流方式

    這篇文章主要介紹了Golang模擬令牌桶進行對訪問的限流方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • Golang http請求封裝的代碼示例

    Golang http請求封裝的代碼示例

    http請求封裝在項目中非常普遍,下面筆者封裝了http post請求傳json、form 和get請求,以備將來使用,文中代碼示例介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • 使用Golang開發(fā)一個簡易版shell

    使用Golang開發(fā)一個簡易版shell

    這篇文章主要為大家詳細介紹了如何使用Golang開發(fā)一個簡易版shell,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • 一文詳解Go語言中切片的底層原理

    一文詳解Go語言中切片的底層原理

    在Go語言中,切片作為一種引用類型數(shù)據(jù),相對數(shù)組而言是一種動態(tài)長度的數(shù)據(jù)類型,使用的場景也是非常多,所以本文主要來和大家聊聊切片的底層原理,需要的可以參考一下
    2023-06-06
  • golang rate令牌桶源碼分析實現(xiàn)方式

    golang rate令牌桶源碼分析實現(xiàn)方式

    這篇文章主要介紹了golang rate令牌桶源碼分析實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Go語言Gin框架中使用MySQL數(shù)據(jù)庫的三種方式

    Go語言Gin框架中使用MySQL數(shù)據(jù)庫的三種方式

    本文主要介紹了Go語言Gin框架中使用MySQL數(shù)據(jù)庫的三種方式,通過三種方式實現(xiàn)增刪改查的操作,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • Golang初始化MySQL數(shù)據(jù)庫方法淺析

    Golang初始化MySQL數(shù)據(jù)庫方法淺析

    這篇文章主要介紹了Golang初始化MySQL數(shù)據(jù)庫的方法,數(shù)據(jù)庫的建立第一步即要初始化,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-05-05
  • golang抓取tcp包的實現(xiàn)方式

    golang抓取tcp包的實現(xiàn)方式

    使用`golang`的`packet`和`pcap`庫可以抓取TCP數(shù)據(jù)包,首先,確保安裝了`pcap`庫,然后使用以下代碼打開網(wǎng)絡(luò)接口,設(shè)置過濾規(guī)則為“tcp”,開始捕獲并解析TCP數(shù)據(jù)包,運行代碼時需要管理員權(quán)限
    2024-12-12
  • golang中的空接口使用詳解

    golang中的空接口使用詳解

    這篇文章主要介紹了golang中的空接口使用,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03

最新評論