二维数组概念:一维数组中的元素又是一个一维数组。
var arr [4][6]int // [ [0 0 0 0 0 0] [0 0 0 0 0 0] [0 0 0 0 0 0] [0 0 0 0 0 0] ]
arr [1][2] = 1
arr [2][3] = 2
arr [3][4] = 3
fmt.Println(arr) // [[0 0 0 0 0 0] [0 0 1 0 0 0] [0 0 0 2 0 0] [0 0 0 0 3 0]]
二维数组内存分析:
[4][6]这个矩阵一共24个int元素,每个int元素在x64计算机内占8bytes,所以这个二维数组占据24*8也就是192Bytes的空间。
由于4个6元素数组构成矩阵,每6个元素为一个数组的首地址一定和a[i]的内存地址是一样的,即为 &a[i] == &a[i][0]。
二维数组遍历
package main
import "fmt"
func main() {
/*
示例,初始化一个二维数组
*/
//写法可以省略,var arr [2][3]int = [2][3]int{
{1,2,3},{4,5,6}}
var arr = [2][3]int{
{1,2,3},{4,5,6}}
fmt.Println(arr)
//传统遍历
for i:=0 ; i < len(arr) ; i++ { //替换为len(arr)
for j := 0 ; j < len(arr[i]) ; j++ { //替换为len(arr[i])
fmt.Printf("%d ",arr[i][j])
}
fmt.Println()
}
// for-range 遍历
for i ,value1 := range arr {
for j , value2 := range value1 {
fmt.Printf("a[%v][%v] = %v\n",i,j,value2)
}
}
}
map的声明
声明:
var <map名字> map[<key的数据类型>]<value的数据类型>
例:
var testmap map[int]int
var testmap1 map[int]string
var testmap2 map[string]string
var testmap3 map[string]map[string]string //定义一个字符串类型的map,每个key对应的values,又是一个字符串类型的map,相当于嵌套。
key:多种类型,布尔,int,float,string,ptr,channel,一般用的最多的是int和string,其他用法很奇怪。
slice,func,map是不可以作为key的,因为无法使用 "=="来判断。
values: 可以是int,string,float,struct,map(见例3)
★★★与数组类型不一样,map的声明是不会分配内存的,初始化需要make(),分配内存后才能赋值和使用,不是默认值为0,"",false等,map与数组不同,是无序的。
类似python中的字典,字典嵌套字典,且无序
示例1:
package main
import "fmt"
func main() {
var testmap map[string]string
fmt.Println(testmap)
} //map[] 这个是反馈结果
示例2:
package main
import "fmt"
func main() {
var testmap map[string]string
testmap["name"] = "durant"
fmt.Println(testmap)
} //panic: assignment to entry in nil map 因为没有分配内存
示例3:
package main
import "fm