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中的切片可以动态操作数据,还是可以方便使用

相关推荐
leobertlan4 小时前
2025年终总结
前端·后端·程序员
面向Google编程5 小时前
从零学习Kafka:数据存储
后端·kafka
易安说AI6 小时前
Claude Opus 4.6 凌晨发布,我体验了一整晚,说说真实感受。
后端
易安说AI6 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
易安说AI6 小时前
用 Claude Code 远程分析生产日志,追踪 Claude Max 账户被封原因
后端
颜酱7 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
Coder_Boy_9 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
掘金者阿豪10 小时前
关系数据库迁移的“暗礁”:金仓数据库如何规避数据完整性与一致性风险
后端
ServBay11 小时前
一个下午,一台电脑,终结你 90% 的 Symfony 重复劳动
后端·php·symfony
sino爱学习11 小时前
高性能线程池实践:Dubbo EagerThreadPool 设计与应用
java·后端