go語(yǔ)言中的二維切片賦值
先用append填充一維的,然后將一維append到二維
代碼如下
var a [][]int for i := 0; i < 10; i++ { var tmp []int for j:= 0; j < 10; j++ { tmp = append(tmp, j) } a = append(a, tmp) }
補(bǔ)充:Go切片的一些技巧
空切片也是切片
與map不同,尚未分配的切片也是可以用的:
一個(gè)nil切片的長(zhǎng)度和容量都是0;你可以append到一個(gè)空切片,Go會(huì)自動(dòng)分配;你也可以直接迭代一個(gè)空切片
var s []int64 // nil, len 0, cap 0 for i := range s { fmt.Println("this will not be printed") } s = append(s, 1) // len 1
結(jié)果就是,如果一個(gè)map的值是slice類型,那么沒(méi)必要為一個(gè)新的key創(chuàng)建一個(gè)slice。
m := map[string][]int64{} for { // do something if _, found := m[key]; !found { m[key] = []int64{value} } else { m[key] = append(m[key], value) } }
上面的代碼可以替換為
m := map[string][]int64{} for { // do something m[key] = append(m[key], value) }
對(duì)一個(gè)切片進(jìn)行重新切片,會(huì)分享同一個(gè)底層數(shù)組
一個(gè)切片就是一個(gè)指向數(shù)組的指針。重新切片(如 s2 := s1[a:b] )就是對(duì)相同的底層數(shù)組創(chuàng)建了一個(gè)新的指針,新的指針具有不同的起始偏移量和切片長(zhǎng)度。
結(jié)果就是,append操作會(huì)修改所有切片。
s1 := []int64{1, 2, 3} s2 := s1[:1] s2 = append(s2,0) fmt.Println(s1) // []int64{1, 0, 3}
……除非需要分配一個(gè)新數(shù)組:
s1 := []int64{1, 2, 3} s2 := s1[:1] s2 = append(s2,0,0,0) // 重新分配了一個(gè)新的底層數(shù)組 fmt.Println(s1) // []int64{1, 2, 3}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
golang雪花算法實(shí)現(xiàn)64位的ID的示例代碼
本文展示了使用Go語(yǔ)言實(shí)現(xiàn)雪花算法生成64位ID的示例代碼,雪花算法通過(guò)當(dāng)前時(shí)間戳、工作節(jié)點(diǎn)ID、數(shù)據(jù)中心ID和序列號(hào)生成唯一的64位ID,確保在分布式系統(tǒng)中的唯一性和時(shí)間順序性,感興趣的可以了解一下2024-09-09Go語(yǔ)言使用protojson庫(kù)實(shí)現(xiàn)Protocol Buffers與JSON轉(zhuǎn)換
本文主要介紹Google開源的工具庫(kù)Protojson庫(kù)如何Protocol Buffers與JSON進(jìn)行轉(zhuǎn)換,以及和標(biāo)準(zhǔn)庫(kù)encoding/json的性能對(duì)比,需要的朋友可以參考下2023-09-09Linux中Go環(huán)境配置和GoModule常用操作
這篇文章主要介紹了Linux中Go環(huán)境配置和GoModule,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-01-01Golang實(shí)現(xiàn)按比例切分流量的示例詳解
我們?cè)谶M(jìn)行灰度發(fā)布時(shí),往往需要轉(zhuǎn)發(fā)一部分流量到新上線的服務(wù)上,進(jìn)行小規(guī)模的驗(yàn)證,隨著功能的不斷完善,我們也會(huì)逐漸增加轉(zhuǎn)發(fā)的流量,這就需要按比例去切分流量,那么如何實(shí)現(xiàn)流量切分呢,接下來(lái)小編就給大家詳細(xì)的介紹一下實(shí)現(xiàn)方法,需要的朋友可以參考下2023-09-09