数组

  • 数组在go语言中为值类型
  • 数组之间可以用= =或!=比较,但是数组长度也是类型的一部分,因此不同长度的数组为不同的类型,如下,这是两个不同类型,因为数组长度不一样,不能用==或!=比较= =
  • 下面ap和at数组是不同类型
ap:=[5]int{3:2}//下标3的值赋值为2
at:=[6]int{}
  • 数组遍历
//数组遍历,i是数组当前下标,p是当前下标对应的值,i可以用_下划线代替,表示忽略
as := [3]int{1, 2, 3}
    for i, p := range as {
        f.Println(i, "---", p)
        pa[i] = &as[i]
    }
    
    
//还可以常用的遍历循环
    le:=len(as)
    for i:=0;i<le;i++{
        f.Println(as[i])
    }
  • 数组指针和指针数组的区别,跟c++没啥区别
//指针数组
    as := [3]int{1, 2, 3}
    var pa [3]*int 
    for i, p := range as {
        f.Println(i, "---", p)
        pa[i] = &as[i]
    }
    
//数组指针
    var pa2 *[3]int
    pa2 = &as
    f.Println(*pa2)

切片 slice

切片不是数组,他是指向底层的数组
创建一般用make方法,第一个参数是指向的数组类型,第二个是存放元素的个数,第三个是存放容量,如果存放的个数超过容量,那么他就会从分配内存地址(容量在原来的基础上*2),len方法获取长度,cap获取容量
如果是简洁声明,不声明数组长度就是切片,譬如

s:=[] int{}//切片
a:=[10] int{1,2,3,4,5,6,7,8,9,10}//数组
c:=a[3,5]//切片c获取数组a下标3到5位元素值,包括3不包括5下标 
d:=a[3:]//下标3到a数组的长度

切片添加元素,方法append

s := make([] int, 5, 10)  //第一个参数表示存储类型,第二个表示存储数组长度,第三个是指如果数组最大长度,如果长度超出10,他就会翻倍,分配一个长度20的内存块,如果不设置,最大容量就是数组长度
    f.Println(len(s), cap(s)) //获取切片长度和容量
    s = append(s, 1, 2, 3, 4, 5, 6)//从尾部添加元素
    s=append(s);    //可以将一个切片添加到另一个切片中
    for _, al := range s {
        f.Println(al)
    }
    //打印结果0 0 0 0 1 2 3 4 5 6
    //为什么打印是10个元素呢,因为他的容量是10,所以打印10个元素

reslice 切片重组

  • 索引以slice为准,索引不可以超过slice切片的容量,越界不会导致底层数组的从新分配,而是报错
a:=[10] int{1,2,3,4,5,6,7,8,9,10}//数组
s:=a[3,5]//切片 输出为[4 5]
rs:=s[0,1] //reslice 输出为[4],下标从切片s的0开始计算,s的下标0对应的值为4
  • 如果rs:=s[0,10]则报错,因为切片s的最大下标为7,即它的容量是7,容量求值方法为:cap(s)

Map集合,跟其他语言一样,是key-value形式

    m := make(map[int]string)
    //m:=map[int]string{0:"0",1:"1"}还可以这样初始化
    m[0] = "first"
    m[1] = "second"
    fm.Println("map is:", m, "--m[0] is:", m[0])
    delete(m, 0)
    fm.Println("m[0] value is:", m)
  • 复杂点的map,如map<key,map<key,value>>形式的
    ms := make(map[int]map[int]string) //只是初始化最外层的map
    mv, ok := ms[0][0]                 //判断里面的map有没有初始化,如果没有,返回false
    if !ok {
        ms[0] = make(map[int]string) //现在初始化value的map
    }
    ms[0][0] = "赋值成功"
    fm.Println("ms is:", ms, " mv is:", mv)
  • 还有数组map,[map<key,value>,map<key,value>]形式的
    ma:=make([]map[int]string,6)//设置数组容量6
    for k:=range ma{
        ma[k]=make(map[int]string,1//设置map容量1
        ma[k][0]="fm"
    }
    fm.Println("ma is:",ma)

    for k, _ := range ma {//遍历数组map
        for k1, v1 := range ma[k] {
            fm.Println("k1 is:", k1, " v1 is:", v1)
        }
    }
  • over