zoukankan      html  css  js  c++  java
  • 【原创】go语言学习(八)切片

    目录:

    • 切片定义
    • 切片基本操作
    • 切片传参
    • make和new的区别

    切片定义

    1. 切片是基于数组类型做的一层封装。它非常灵活,可以自动扩容。

    var a []int
    //定义一个int类型的空切⽚
    

      

    2. 切片初始化, a[start:end]创建一个包括从start到end-1的切片。

    package main
    import (
        "fmt"
    )
    func main() {
        a := [5]int{76, 77, 78, 79, 80}
        var b []int = a[1:4] //基于数组a创建一个切片,包括元素a[1] a[2] a[3]
        fmt.Println(b)
    }
    

      

    3. 切片初始化方法2。

    package main
    import (
        "fmt"
    )
    func main() {
        c := []int{6, 7, 8} //创建⼀一个数组并返回⼀一个切⽚片
        fmt.Println(c)
    }
    

      

    切片基本操作

    1. 数组切片的基本操作
    a) arr[start:end]:包括start到end-1(包括end-1)之间的所有元素
    b) arr[start:]:包括start到arr最后⼀一个元素(包括最后一个元素)之间的所有元素
    c) arr[:end]:包括0到end-1(包括end-1)之间的所有元素
    d) arr[:]:包括整个数组的所有元素

    package main
    import (
        "fmt"
    )
    func main() {
        //创建一个数组,其中[…]是编译器器确定数组的长度,darr的长度是9
        darr := [...]int{57, 89, 90, 82, 100, 78, 67, 69, 59}
        //基于darr创建一个切片dslice,包括darr[2],darr[3],darr[4]三个元素
        dslice := darr[2:5]
        fmt.Println("array before",darr)
        for i := range dslice {
            //对于dslice中每个元素进行+1,其实修改是darr[2],darr[3],darr[4]
            dslice[i]++
        }
        fmt.Println("array after",darr)
    }    
    

      

    2、切片修改

    package main
    import (
        "fmt"
    )
    func main() {
        numa := [3]int{78, 79 ,80}
        //创建⼀一个切⽚片,包含整个数组的所有元素
        nums1 := numa[:]
        nums2 := numa[:]
        fmt.Println("array before change 1",numa)
        nums1[0] = 100
        fmt.Println("array after modification to slice nums1", numa)
        nums2[1] = 101
        fmt.Println("array after modification to slice nums2", numa)
    }
    

      

    3、使用make创建切片

    package main
    import (
        "fmt"
    )
    func main() {
        //[]中没有⻓长度
        i := make([]int, 5, 5)
        fmt.Println(i)
    }
    

      

    4、切片的长度和容量

    package main
    import (
        "fmt"
    )
    func main() {
        fruitarray := […]string{
            "apple", "orange", "grape",
            "mango", "water melon",
            "pine apple", "chikoo"
        }
        fruitslice := fruitarray[1:3]
        //⻓长度是2,容量量is 6
        fmt.Printf("length of slice %d capacity %d",
            len(fruitslice), cap(fruitslice))
    }        
    

      

    5、切片的再切片

    package main
    import (
        "fmt"
    )
    func main() {
        fruitarray := […]string{
            "apple", "orange", "grape", "mango",
            "water melon", "pine apple", "chikoo"
        }
        fruitslice := fruitarray[1:3]
        //⻓长度是2, 容量量是6
        fmt.Printf("length of slice %d capacity %d
    ",
        len(fruitslice), cap(fruitslice))
        //再重新进⾏行行切⽚片,不不能⼤大于数组fruitarray的⻓长度,否则越界
        fruitslice = fruitslice[:cap(fruitslice)]
        fmt.Println("After re-slicing length is”,
          len(fruitslice), "and capacity is",cap(fruitslice))
    }
    

      

    6、空切片

    package main
    import (
        "fmt"
    )
    func main() {
        //定义names是⼀一个空切⽚片,⻓长度和容量量都等于0
        //不不能对空切⽚片进⾏行行访问,否则panic
        var names []string
        if names == nil {
            fmt.Println("slice is nil going to append")
            names = append(names, "John", "Sebastian", "Vinay")
            fmt.Println("names contents:",names)
        }
    }
    

      

    7、append一个切片

    package main
    import (
        "fmt"
    )
    func main() {
        veggies := []string{"potatoes","tomatoes","brinjal"}
        fruits := []string{“oranges","apples"}
        //fruits后⾯面的3个点表示展开fruits切⽚片成⼀一个个元素
        food := append(veggies, fruits...)
        fmt.Println("food:",food)
    }
    

      

    切片传参

    1、切片传参

    package main
    import (
        "fmt"
    )
    //在函数内部修改numbers切⽚片的值
    func subtactOne(numbers []int) {
        for i := range numbers {
        numbers[i] -= 2
    }
    }
    func main() {
        nos := []int{8, 7, 6}
        fmt.Println("slice before function call", nos)
        subtactOne(nos)
        //nos修改生效了了,说明切片是引⽤用类型
        fmt.Println("slice after function call", nos)
    }
    

      

    2、切片拷贝

    package main
    import (
        "fmt"
    )
    func main() {
        veggies := []string{"potatoes","tomatoes","brinjal"}
        fruits := []string{“oranges","apples"}
        copy(veggies, fruits)
        fmt.Println(veggies, fruits)
    }
    

     

    3、切片遍历

    var a [3]int
    a[0] = 10
    a[1] = 20
    a[2] = 30
    B := a[:]
    for index, val := range b {
    }
    //和数组遍历是⼀一样的
    

      

    make和new的区别

    1、 make为内建类型slice、map和channel分配内存。

    //初始化一个切⽚片
    s := make([]int, 10, 30)
    

      

    2、new⽤用于各种类型的内存分配,new返回是一个指针。

  • 相关阅读:
    stm32 SPI DMA读取ADS8345数据
    Minigui3.0.12完美安装,折腾了一天。终于看到了
    qvfb2的安装,在ubuntu10.4上安装成功
    户口从杭州人才市场迁移到武汉万科魅力之城的过程
    禁止minigui 3.0的屏幕保护
    想穿越回到儿时记录那些幸福
    TIM2定时闪灯程序。。。
    关于minigui的皮肤控件无法显示问题
    插件框架内核的设计
    用“序列图”描述技术方案
  • 原文地址:https://www.cnblogs.com/wangshuyang/p/11800798.html
Copyright © 2011-2022 走看看