golang的array/slice

相同点

  • 由相同类型的元素组合构成
  • 元素有序排列,0为第一个元素下标
  • 基本使用方法相同

区别

array声明时需要指定容量大小,而且无法修改

slice可通过append增加元素,当容量不够时,会自动扩容

array传递类型:值拷贝;slice传递类型:引用拷贝(有两种情况坑)

声明

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
var array名 [容量]元素类型
array名 :=[3]元素类型{元素1,元素2,元素3}
 
var slice名 []元素类型
slice名 := make([]类型,容量)  //建议这样声明
slice名 := []元素类型{元素1,元素2,元素3}
// array或者slice声明后,各元素并不为空,而是该元素类型的 *零 *值
 
//array声明时还可以让编译器自动导入元素容量
array名 := [10]int{5:199, 8:200}
 
//多维array/slice
//由相同元素类型构成的array/slice 为元素构成的array结构
 
array名 := [3][2]int{{1,2},{3,5},{9,2}}
slice名 := [][]int{{1,2},{3,5},{9,2}}
 
//元素赋值
a[index] = 值

array/slice容量属性len/cap

  • len
    • len()方法获取array/slice的元素个数
  • cap
    • cap()方法获取array/slice的最大值可存储元素个数
  •   

根据开始我们说的array和slice特性

array: len和cap值时相等的

slice:初始化时,len和cap值是相等的,当append操作达到当前cap临界点时,cap值会增大

此时,len与cap的值是不相等的

array/slice遍历

  • 方法一
    1
    2
    3
    for index, value := rang a{
         fmt.Println(index, value)
    }  
  • 方法二
    1
    2
    3
    for index := range a{
          fmt.Println(a[index])
    }  
  • 方法三
    1
    2
    3
    4
    //len()获取array元素数量
    for  i :=0; i<len(a); i++{
         fmt.Println(a[i])
    } 
  • 多维遍历
    1
    2
    3
    4
    5
    6
    b := [3][2]int{{1,2},{3,5},{9,2}}
    for index, value := range b{
          for i, v := range value{
                fmt.Println(index, i. v)
         }
    }  
  • 切片操作
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    a := [5]int{10, 20, 30, 40, 50}
     
    //取出前三个元素, 坐标分别是 0, 1, 2
    b := a[0:3]
    bb := a[:3]
     
    //取出第三个元素之后所有元素(包含第3个元素)
    c := a[2:]
     
    //取出第2, 3, 4 三个元素
    d := a[1:4]  
slice引⽤用传递的坑 分两种情况: 主slice⾃自动扩容之前 ⾃自动扩容之后
1
2
3
4
5
6
7
8
9
10
11
12
13
s1 := []int{1, 2}
s2 := s1
fmt.Println(s1[0])
fmt.Println(s2[0])
s1[0] = 100
fmt.Println(s1[0])
fmt.Println(s2[0])
 
temp := []int{5, 6, 7, 8, 9, 10, 11, 12, 13, 14}
s1 = append(s1, temp...)
s1[0] = 1000
fmt.Println(s1[0])
fmt.Println(s2[0])

  

 

posted @   Dwyane.wang  阅读(288)  评论(0编辑  收藏  举报
编辑推荐:
· 智能桌面机器人:用.NET IoT库控制舵机并多方法播放表情
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
阅读排行:
· 手把手教你在本地部署DeepSeek R1,搭建web-ui ,建议收藏!
· 新年开篇:在本地部署DeepSeek大模型实现联网增强的AI应用
· Janus Pro:DeepSeek 开源革新,多模态 AI 的未来
· 互联网不景气了那就玩玩嵌入式吧,用纯.NET开发并制作一个智能桌面机器人(三):用.NET IoT库
· 【非技术】说说2024年我都干了些啥
点击右上角即可分享
微信分享提示