go语言中的二维切片赋值

2022-10-13,,

这篇文章主要介绍了go语言中的二维切片赋值操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

先用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)
}

补充:Go切片的一些技巧

空切片也是切片

与map不同,尚未分配的切片也是可以用的:

一个nil切片的长度和容量都是0;你可以append到一个空切片,Go会自动分配;你也可以直接迭代一个空切片

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

结果就是,如果一个map的值是slice类型,那么没必要为一个新的key创建一个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)
}

对一个切片进行重新切片,会分享同一个底层数组

一个切片就是一个指向数组的指针。重新切片(如 s2 := s1[a:b] )就是对相同的底层数组创建了一个新的指针,新的指针具有不同的起始偏移量和切片长度。

结果就是,append操作会修改所有切片。

s1 := []int64{1, 2, 3}
s2 := s1[:1]
s2 = append(s2,0)
fmt.Println(s1) // []int64{1, 0, 3}

……除非需要分配一个新数组:

s1 := []int64{1, 2, 3}
s2 := s1[:1]
s2 = append(s2,0,0,0) // 重新分配了一个新的底层数组
fmt.Println(s1) // []int64{1, 2, 3}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持北冥有鱼。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:

  • go语言求任意类型切片的长度操作
  • 如何在Go中使用切片容量和长度
  • Go语言切片前或中间插入项与内置copy()函数详解
  • golang中切片copy复制和等号复制的区别介绍
  • go语言中切片与内存复制 memcpy 的实现操作
  • go语言中切片的长度和容量的区别

《go语言中的二维切片赋值.doc》

下载本文的Word格式文档,以方便收藏与打印。