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

相关推荐
Lee川3 小时前
LangChain 加持:后端 AI 流式对话的优雅实现
后端
子兮曰5 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
ltl5 小时前
Self-Attention:让序列自己看自己
后端
楼兰公子5 小时前
buildroot 在编译rust时裁剪平台类型数量的方法
开发语言·后端·rust
吴声子夜歌5 小时前
Go——并发编程
开发语言·后端·golang
释怀°Believe5 小时前
Spring解析
java·后端·spring
Cosolar6 小时前
大模型应用开发面试 • 每日三题|Day 003|多Agent系统中的通信协议、冲突解决和一致性保障
人工智能·后端·面试
汪汪大队u6 小时前
续:从 Docker Compose 到 Kubernetes(2)—— 服务优化与排错
网络·后端·物联网·struts·容器
无风听海7 小时前
MapStaticAssets()深度解析:ASP.NET Core 静态资源交付的现代范式
后端·asp.net
geovindu8 小时前
go: Lock/Mutex Pattern
开发语言·后端·设计模式·golang·互斥锁模式