go中的切片

前言

go有着数组和切片两种方式,数组一旦创建,长度就不可以被修改,但是切片,可以按需自动增长,自动扩容

go中的数组

go中的数组定义

css 复制代码
package main

import "fmt"

func main() {
    var a = [3]int{1, 2, 3}
    a[0] = 1
    a[1] = 2
    a[2] = 3
    fmt.Println(a)
}

这个时候,该数组是不能被扩容的,也就是不能使用append增加数组元素

切片

切片的创建与初始化

可以在创建的时候,不指定长度

go 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3}
    fmt.Println(a)
}

或者使用make初始化

go 复制代码
package main

import "fmt"

func main() {
    var a = make([]int, 5)
    fmt.Println(a)
}

也可以使用指定索引方式

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1: 1, 3: 3, 5: 5}
    fmt.Println(a)
}

输出结果为

可以创建一个空的切片,但是如果数组下标超过切片,那么就会报错

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{}
    fmt.Println(a[0])
}

输出结果为

切片复制

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    b := a[1:3]
    fmt.Println(b)
}

输出结果为

复制索引1到3的元素, 注意新切片不包含索引为3的元素

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    b := a[1:]
    fmt.Println(b)
}

输出结果为

从索引1开始复制,到数组结束

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    b := a[:3]
    fmt.Println(b)
}

输出结果为

这里是从索引0开始复制,然后到索引2

备注

这里需要注意的是,复制出来的切片,修改元素的值,会影响原来切片的值

less 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    b := a[1:]
    fmt.Println(b)
    b[0] = 10
    fmt.Println(a)
}

输出结果为

append

可以使用append增加切片数据

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    a = append(a, 12)
    fmt.Println(a)
}

输出结果为

新增多个元素

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    a = append(a, 12)
    var b = []int{1, 2, 3}
    a = append(a, b...)
    fmt.Println(a)
}

输出结果为

切片移除元素

可以使用切片移除元素

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    a = append(a[:1], a[3:]...)
    fmt.Println(a)
}

输出结果为

切片遍历

css 复制代码
package main

import "fmt"

func main() {
    var a = []int{1, 2, 3, 4, 5, 6}
    for i := 0; i < len(a); i++ {
       fmt.Println(a[i])
    }
}

输出结果为

二维切片声明

css 复制代码
package main

import "fmt"

func main() {
    var a = [][]int{{1}, {2}}
    fmt.Println(a)
}

输出结果为

或者使用

go 复制代码
package main

import "fmt"

func main() {
    var a = make([][]int, 3)
    fmt.Println(a)
}

总结

go中的切片可以动态操作数据,还是可以方便使用

相关推荐
oak隔壁找我6 小时前
MySQL中 SHOW FULL PROCESSLIST` 输出中 `State` 列的所有可能值
后端
上进小菜猪7 小时前
基于 YOLOv8 的面向文档智能处理的表格区域检测系统 [目标检测完整源码]
后端
oak隔壁找我7 小时前
JVM常用调优参数
java·后端
IT_陈寒11 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
晨星shine11 小时前
GC、Dispose、Unmanaged Resource 和 Managed Resource
后端·c#
蝎子莱莱爱打怪11 小时前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
倚栏听风雨12 小时前
【ES避坑指南】明明存的是 "CodingAddress",为什么 term 查询死活查不到?彻底搞懂 text 和 keyword
后端
程序员爱钓鱼12 小时前
Go 操作 Windows COM 自动化实战:深入解析 go-ole
后端·go·排序算法
回家路上绕了弯12 小时前
深入解析Agent Subagent架构:原理、协同逻辑与实战落地指南
分布式·后端
子玖13 小时前
实现微信扫码注册登录-基于参数二维码
后端·微信·go