1.数组指针
    (1)数组指针与指针数组
        这俩概念原本在c语言中就是一个绕口令般的存在,尽管从类型角度来看两者并没什么相似的地方。
        但是在go语言中对这两个类型的设定做出了一些不同的规定。首先交代一下基本概念:
            数组指针:指的是一个指针,只不过这个指针指向了一个数组
                eg:
                    var arr [5]int = [5]int{1,2,3,4,5};
                    var p *[5]int = &arr;
                    fmt.Println(p);//0xc00006a030
                    //此时p称为是数组arr的指针
                    //此时如果通过p访问数组元素是 (*p)[2],结果是3
            指针数组:指的是一个数组,这个数组里面装满了指针。
                eg:
                    var arr1 [5]int = [5]int{1,2,3,4,5};
                    var arr2 [5]int = [5]int{6,7,8,9,0};
                    var p1 *[5]int = &arr1;
                    var p2 *[5]int = &arr2;
                    var pArr [2]*[5]int = [2]*[5]int{p1,p2};
                    fmt.Println(pArr);//[0xc00006a030, 0xc00006a060]
                    //此时pArr称为是指针数组
                    //此时如果通过pArr访问数组元素是 (*pArr[0])[2],结果是3
    (2)地址相同、类型不同问题
        在go语言中,内存地址相同并不意味着其表示的数据或者数据类型就完全相同。
        eg:
            var arr [5]int = [5]int{1,2,3,4,5};
            p1,p2 := &arr,&arr[0];
            fmt.Println(p1);        //&[1,2,3,4,5] 整个数组的内存地址
            fmt.Println(p2);        //0xc0000180c0 数组第一个元素的内存地址
            fmt.Printf("%T",p1);    //*[5]int    数组指针