关于Golang切片的三种简单使用方式及区别


本文摘自php中文网,作者藏色散人,侵删。

下面由golang教程栏目关于Golang切片的三种简单使用方式及区别,希望对需要的朋友有所帮助!

概念

切片(slice)是建立在数组之上的更方便,更灵活,更强大的数据结构。切片并不存储任何元素而只是对现有数组的引用。

三种方式及细节案例

①定义一个切片,然后让切片去引用一个已经创建好的数组

1

2

3

4

5

6

7

8

9

package main

import (    "fmt")

 

func main() {    var arr [5]int = [...]int {1, 2, 3, 4, 5}    var slice = arr[1:3]

    fmt.Println("arr=", arr)

    fmt.Println("slice=", slice)

    fmt.Println("slice len", len(slice))

    fmt.Println("slice cap", cap(slice))

}

②通过make来创建切片。基本语法:var 切片名 []type = make([], len, [cap]);参数说明:type是数据类型、len是大小、cap是切片容量(容量必须>=长度)

  1. 通过make方式创建切片可以指定切片大小和容量
  2. 如果没有给切片的各个元素赋值,那么就会使用默认值(int、float=>0, strint=>"", bool=>false)
  3. 荣国make方式创建的切片对应的数组是由make底层维护,对外不可见,也就是只能通过slice访问各个元素

1

2

3

4

5

6

7

8

9

10

11

12

package main

import (    "fmt")

 

 

func main() {    var slice []float64 = make([]float64, 5, 10)    //没有给值,默认都是0

    fmt.Println(slice)  //[0 0 0 0 0]    //赋值

    slice[1] = 5

    slice[3] = 10 

    fmt.Println(slice)  //[0 5 0 10 0]

 

    fmt.Println("slice大小:", len(slice)) //slice大小: 5

    fmt.Println("slice容量:", cap(slice)) //slice容量: 10}

③定义一个切片,直接就指定具体数组,使用原理类似于make的方式

1

2

3

4

5

6

7

8

package main

import (    "fmt")

 

 

func main() {    var slice []string = []string{"zhangsan", "lisi", "wangwu"}

    fmt.Println("slice=", slice) //slice= [zhangsan lisi wangwu]

    fmt.Println("slice len", len(slice)) //slice len 3

    fmt.Println("slice cap", cap(slice)) //slice cap 3}

第一种和第二种的区别

第一种方式是直接引用数组,这个数组是事先存在的,程序员可见
第二种方式是通过make来创建切片,make也会创建一个数组,是由切片在底层维护,程序员不可见

补充:零碎案例

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

package main

import "fmt"func main() {    // 和数组不同的是,切片的长度是可变的。    // 我们可以使用内置函数make来创建一个长度不为零的切片    // 这里我们创建了一个长度为3,存储字符串的切片,切片元素    // 默认为零值,对于字符串就是""。

    s := make([]string, 3)

    fmt.Println("emp:", s)    // 可以使用和数组一样的方法来设置元素值或获取元素值

    s[0] = "a"

    s[1] = "b"

    s[2] = "c"

    fmt.Println("set:", s)

    fmt.Println("get:", s[2])    // 可以用内置函数len获取切片的长度

    fmt.Println("len:", len(s))    // 切片还拥有一些数组所没有的功能。    // 例如我们可以使用内置函数append给切片追加值,然后    // 返回一个拥有新切片元素的切片。    // 注意append函数不会改变原切片,而是生成了一个新切片,    // 我们需要用原来的切片来接收这个新切片

    s = append(s, "d")

    s = append(s, "e", "f")

    fmt.Println("apd:", s)    // 另外我们还可以从一个切片拷贝元素到另一个切片    // 下面的例子就是创建了一个和切片s长度相同的新切片    // 然后使用内置的copy函数来拷贝s的元素到c中。

    c := make([]string, len(s))

    copy(c, s)

    fmt.Println("cpy:", c)    // 切片还支持一个取切片的操作 "slice[low:high]"    // 获取的新切片包含元素"slice[low]",但是不包含"slice[high]"    // 下面的例子就是取一个新切片,元素包括"s[2]","s[3]","s[4]"。

    l := s[2:5]

    fmt.Println("sl1:", l)    // 如果省略low,默认从0开始,不包括"slice[high]"元素

    l = s[:5]

    fmt.Println("sl2:", l)    // 如果省略high,默认为len(slice),包括"slice[low]"元素

    l = s[2:]

    fmt.Println("sl3:", l)    // 我们可以同时声明和初始化一个切片

    t := []string{"g", "h", "i"}

    fmt.Println("dcl:", t)    // 我们也可以创建多维切片,和数组不同的是,切片元素的长度也是可变的。

    twoD := make([][]int, 3)    for i := 0; i < 3; i++ {

        innerLen := i + 1

        twoD[i] = make([]int, innerLen)        for j := 0; j < innerLen; j++ {

            twoD[i][j] = i + j

        }

    }

    fmt.Println("2d: ", twoD)

}

1

2

3

4

5

6

7

8

//结果emp: [  ]set: [a b c]get: c

len: 3apd: [a b c d e f]

cpy: [a b c d e f]

sl1: [c d e]

sl2: [a b c d e]

sl3: [c d e f]

dcl: [g h i]

2d:  [[0] [1 2] [2 3 4]]

以上就是关于Golang切片的三种简单使用方式及区别的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

golang无法导包怎么办?

go实现安全并发map读写

编写可测试的 go 代码

golang nil 小知识

golang双向链表

手撸golang spring ioc/aop 之2

专访go语言布道师dave cheney:go语言这十年,只能用“成功”一词总结

go关于tpl文件无法读取域中数据{{$.name}}

json序列化在golang中的应用

golang如何获取客户端ip?

更多相关阅读请进入《golang》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...