len规则:s[x:y], len为 y-x 的值。

cap规则:一个切片的容量可以被看做是透过这个窗口最多可以看到的底层数据中元素的个数,在底层数组不变的情况下,切片代表的窗口可以向右扩展,纸质底层数组的末尾。

即在底层数组中剩余的元素个数


The start and end indices of a slice expression are optional; they default to zero and the slice's length

[x:y], x默认为0,y默认为slice的len,即len(s)

package main

import "fmt"

func main() {

    // 1.创建了底层数据,并且新建了分片以引用,底层数组为[2,3,5,7,11,13]
    s := []int{2, 3, 5, 7, 11, 13}
    printSlice(s)

    // 2.Slice the slice to give it zero length.
    // s[:0]其实就是s[0:0],长度len为 high-low的数值,即为0 , 容量cap为 6 ,为在底层数组中剩余的元素个数
    // 结果s为[]
    s = s[:0]
    printSlice(s)

    // 3.Extend its length.
    // s[:4]其实就是s[0:4],长度len为 4-0,即为4, 容量cap为 6, 为在底层数组中剩余的元素个数
    // 结果s为[2,3,5,7]
    s = s[:4]
    printSlice(s)


    // 4.Drop its first two values.
    // s[2:]其实就是s[2:len(s)],即s[2:4],而这个len(s)中的s为前面的代码的s,len为2,容量cap为4 ,为在底层数组中剩余的元素个数
    // 结果s为[5,7]
    s = s[2:]
    printSlice(s)


    // 5. s[1:]其实就是s[1:len(s)],即s[1:2],len为1, 容量cap为3, 为在底层数组中剩余的元素个数
    // 结果s为[7]
    s = s[1:]
    printSlice(s)
    
}

func printSlice(s []int) {
    fmt.Printf("len=%d cap=%d %v\n", len(s), cap(s), s)
}