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

相关推荐
GetcharZp1 天前
GitHub 49K+ Star!C++ 开发者必知的 JSON 神级库:从零到精通全指北
后端
xujinwei_gingko1 天前
SpringBoot整合WebSocket
spring boot·后端·websocket
智码看视界1 天前
现代Web开发基础:全栈工程师的起航点
前端·后端·c5全栈
程序员cxuan1 天前
Claude Fable 5 来了
人工智能·后端·程序员
JS菌1 天前
手写一个 AI Agent 全栈项目:从沙箱执行到子智能体的完整实现
前端·人工智能·后端
wang09071 天前
自己动手写一个spring之IOC_2
java·后端·spring
ltl1 天前
推理退化:为什么大模型会输出乱码、死循环和无意义文本
后端
ltl1 天前
架构视图与文档:C4 模型从入门到实战
后端
IT_陈寒1 天前
Redis持久化这个坑,我爬了一整天才出来
前端·人工智能·后端
无风听海1 天前
多租户系统中的 OIDC:Discovery 端点与联合登录的深度实践
后端·python·flask