var 数组变量名 [元素数量]T

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/li123128/article/details/102733703

  var 数组变量名 [元素数量]T
  
  比如:var a [5]int, 数组的长度必须是常量,并且长度是数组类型的一部分。一旦定义,长度不能变。 [5]int和[10]int是不同的类型。
  
  var a [3]int
  
  var b [4]int
  
  a = b //不可以这样做,因为此时a和b是不同的类型
  
  数组可以通过下标进行访问,下标是从0开始,最后一个元素下标是:len-1,访问越界(下标在合法范围之外),则触发访问越界,会panic。
  
  数组的初始化
  
  数组的初始化也有很多方式。
  
  方法一
  
  初始化数组时可以使用初始化列表来设置数组元素的值。
  
  func main() {
  
  var testArray [3]int                        //数组会初始化为int类型的零值
  
  var numArray = [3]int{1, 2}                 //使用指定的初始值完成初始化
  
  var cityArray = [3]string{"北京", "上海", "深圳"} //使用指定的初始值完成初始化
  
  fmt.Println(testArray)                      //[0 0 0]
  
  fmt.Println(numArray)                       //[1 2 0]
  
  fmt.Println(cityArray)                      //[北京 上海 深圳]
  
  }
  
  方法二
  
  按照上面的方法每次都要确保提供的初始值和数组长度一致,一般情况下我们可以让编译器根据初始值的个数自行推断数组的长度,例如:
  
  func main() {
  
  var testArray [3]int
  
  var numArray = [...]int{1, 2}
  
  var cityArray = [...]string{"北京", "上海", "深圳"}
  
  fmt.Println(testArray)                          //[0 0 0]
  
  fmt.Println(numArray)                           //[1 2]
  
  fmt.Printf("type of numArray:%T\n", numArray)   //type of numArray:[2]int
  
  fmt.Println(cityArray)                          //[北京 上海 深圳]
  
  fmt.Printf("type of cityArray:%T\n", cityArray) //type of cityArray:[3]string
  
  }
  
  方法三
  
  我们还可以使用指定索引值的方式来初始化数组,例如:
  
  func main() {
  
  a := [...]int{1: 1, 3: 5}
  
  fmt.Println(a)                  // [0 1 0 5]
  
  fmt.Printf("type of a:%T\n", a) //type of a:[4]int
  
  }
  
  数组的遍历
  
  遍历数组a有以下两种方法:
  
  func main() {
  
  var a = [...]string{"北京", "上海", "深圳"}
  
  // 方法1:for循环遍历
  
  for i := 0; i < len(a); i++ {
  
  fmt.Println(a[i])
  
  # 日期转换, 将dt 转换为日期,取年份, 注意map的用法
  
  climate['dt'] = pd.to_datetime(climate['dt'])
  
  climate['year'] www.yinchengyule.cn= climate['dt'www.gouyiflb.cn ].map(lambda value: value.year)
  
  climate_sub_china www.yinchengylzc.cn= climate.loc[climate['Country'] == 'China']
  
  climate_sub_china[ www.hengxinylpt.cn'Century'] = climate_sub_china['year'].map(lambda x:int(x/100 +1))
  
  climate_sub_china.head()
  
  多维数组
  
  Go语言是支持多维数组的,我们这里以二维数组为例(数组中又嵌套数组)。
  
  二维数组的定义
  
  func main() {
  
  a := [3][2]string{
  
  {"北京", "上海"},
  
  {"广州", "深圳"},
  
  {"成都", "重庆"},
  
  }
  
  fmt.Println(a) //[[北京 上海] [广州 深圳] [成都 重庆]]
  
  fmt.Println(a[2][1]) //支持索引取值:重庆
  
  }
  
  二维数组的遍历
  
  func main() {
  
  a := [3][2]string{
  
  {"北京", "上海"},
  
  {"广州", "深圳"},
  
  {"成都", "重庆"},
  
  }
  
  for _, v1 := range a {
  
  for _, v2 := range v1 {
  
  fmt.Printf("%s\t", v2)
  
  }
  
  fmt.Println()
  
  }
  
  }
  
  输出:
  
  北京  上海
  
  广州  深圳
  
  成都  重庆
  
  注意: 多维数组只有第一层可以使用...来让编译器推导数组长度。例如:
  
  //支持的写法
  
  a := [...][2]string{
  
  {"北京", "上海"},
  
  {"广州", "深圳"},
  
  {"成都", "重庆"},
  
  }
  
  //不支持多维数组的内层使用...
  
  b := [3][...]string{
  
  {"北京", "上海"},
  
  {"广州", "深圳"},
  
  {"成都", "重庆"},
  
  }
  
  数组是值类型
  
  数组是值类型,赋值和传参会复制整个数组。因此改变副本的值,不会改变本身的值。
  
  func modifyArray(x [3]int) {
  
  x[0] = 100
  
  }
  
  func modifyArray2(x [3][2]int) {
  
  x[2][0] = 100
  
  }
  
  func main() {
  
  a := [3]int{10, 20, 30}
  
  modifyArray(a) //在modify中修改的是a的副本x
  
  fmt.Println(a) //[10 20 30]
  
  b := [3][2]int{
  
  {1, 1},
  
  {1, 1},
  
  {1, 1},
  
  }
  
  modifyArray2(b) //在modify中修改的是b的副本x
  
  fmt.Println(b)  //[[1 1] [1 1] [1 1]]
  
  }
  
  注意:
  
  数组支持 “==“、”!=” 操作符,因为内存总是被初始化过的。
  
  [n]*T表示指针数组,*[n]T表示数组指针 。
  
  标签: Go基础
  
  Dr_wei
  
  关注 - 13
  
  粉丝 - 0

猜你喜欢

转载自blog.csdn.net/li123128/article/details/102733703