map切片:

切片的数据类型如果是map,则我们称为 slice of map, map切片,这样使用则map个数就可以动态变化了。

案例演示:
要求:会用一个map来记录monster的信息 name 和 age,也就是说一个monster 对应一个map,并且妖怪的个数可以动态的增加=>map切片

func main() {

  //1.声明一个map切片
  var monsters []map[string]string
  monsters = make([]map[string]string, 2) //准备放入2个妖怪
  //2.增加第一个妖怪的信息
  if monsters[0] == nil {
    monsters[0] = make(map[string]string)
    monsters[0]["name"] = "牛魔王"
    monsters[0]["age"] = "500"
  }

  if monsters[1] == nil {
    monsters[1] = make(map[string]string)
    monsters[1]["name"] = "玉兔精"
    monsters[1]["age"] = "400"
  }

  //下面这个写法越界。
  /*
  if monsters[2] == nil {
    monsters[2] = make(map[string]string)
    monsters[2]["name"] = "狐狸精"
    monsters[2]["age"] = "300"
  }
  */

  //这里我们需要使用到切片的append函数,可以动态的增加一个妖怪
  //1.先顶一个monster信息
  newMonster := map[string]string {
    "name" : "新的妖怪~火云邪神",
    "age" : "200",
  }
  monsters = append(monsters, newMonster)
  fmt.Println(monsters)
}

map排序:

基本介绍:

1)golang中没有一个专门的方法针对map的key进行排序

2)golang中的map默认是无序的,注意也不是按照添加顺序存放的,你每次遍历,得到的输出可能都不一样。

3)golang中map的排序,是先将key进行排序,然后根据key值遍历输出即可。

案例演示:

package main
import (
  "fmt"
  "sort"
)

func main() {

  map1 := make(map[int]int, 10)
  map1[10] = 100
  map1[1] = 13
  map1[4] = 56
  map1[8] = 90
  //如果按照map的key的顺序进行排序输出
  //1.先将map的key 放入到 切片中
  //2.对切片排序
  //3.遍历切片,按照key来输出这个map的值
  var keys []int
  for k, _ := range map1 {
    keys = append(keys, k)
  }
  //排序
  sort.Ints(keys)
  for _, k := range keys {
    fmt.Printf("map1[%v]=%v \n", k, map1[k])
  }
}

map使用细节:

1)map是引用类型,遵守引用类型传递的机制,在一个函数接收map,修改后,会直接修改原来的map

func modify(map1 map[int]int){
  map1[10] = 900
}

func main() {
  map1 := make(map[int]int)
  map1[1] = 90
  map1[2] = 88
  map1[10] = 1
  map1[20] = 2
  modify(map1)
  fmt.Println(map1)
}

2)map的容量达到后,再想map增加元素,会自动扩容,并不会发生panic,也就是说map 能动态的增长 键值对(key-value)

3)map的value 也经常使用struct 类型,更适合管理复杂的数据(比前面value是一个map更好),比如value为 Student 结构体

func main() {

  //1.map 的 key 为学生的学号,是唯一的
  //2.map 的 value 为结构体,包含学生的 名字,年龄,住址

  students := make(map[string]Stu, 10)
  //创建2个学生
  stu1 := Stu{"tom", 18, "北京",}
  stu2 := Stu{"mary", 28, "上海"}
  students["no1"] = stu1
  students["no2"] = stu2

  //遍历各个学生信息
  for k, v := range students {
    fmt.Printf("学生的编号是%v \n", k)
    fmt.Printf("学生的名字是%v \n", v.Name)
    fmt.Printf("学生的年龄是%v \n", v.Age)
    fmt.Printf("学生的住址是%v \n", v.Address)
    fmt.Println()
  }
}

Map3的更多相关文章

  1. java 集合(Map3)

    Map接口下的实现类: HashMap 1.存储原理: 向HashMap中添加元素时,首先会调用hashCode(),算的哈希值,然后 算出该元素在哈希表中的存储位置. 情况1 情况2(java  集 ...

  2. Scala中List(Map1,Map2,Map3 ....) 转成一个Map

    这个问题研究好久...头大,不记得有fold用法了. fold函数:折叠,提供一个输入参数作为初始值,然后大括号中应用自定义fun函数并返回值. list.fold(Map()){(x,y)=> ...

  3. UNITY所谓的异步加载几乎全部是协程,不是线程;MAP3加载时解压非常慢

    实践证明,以下东西都是协程,并非线程(thread): 1,WWW 2,AssetBundle.LoadFromFileAsync 3,LoadSceneAsync 其它未经测试 此问题的提出是由于一 ...

  4. [Hadoop in Action] 第5章 高阶MapReduce

    链接多个MapReduce作业 执行多个数据集的联结 生成Bloom filter   1.链接MapReduce作业   [顺序链接MapReduce作业]   mapreduce-1 | mapr ...

  5. 龙之谷手游WebVR技术分享

    主要面向Web前端工程师,需要一定Javascript及three.js基础:本文主要分享内容为基于three.js开发WebVR思路及碰到的问题:有兴趣的同学,欢迎跟帖讨论. 目录:一.项目体验1. ...

  6. MapReduce工作流多种实现方式

    学习 hadoop,必不可少的就是编写 MapReduce 程序.当然,对于简单的分析程序,我们只需一个 MapReduce 任务就能搞定,然而对于比较复杂的分析程序,我们可能需要多个Job或者多个M ...

  7. GO语言总结(4)——映射(Map)

    上一篇博客介绍了Go语言的数组和切片——GO语言总结(3)——数组和切片,本篇博客介绍Go语言的映射(Map) 映射是一种内置的数据结构,用来保存键值对的无序集合. (1)映射的创建 make ( m ...

  8. java从基础知识(七)java集合

    一.集合类介绍 1.List(元素有放入顺序,可重复) 1.1.List的实现 1.1.1.ArrayList ArrayList就是动态数组(需要连续的存储空间),用MSDN中的说法,就是Array ...

  9. Java json串生成及转bean

      package com; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import j ...

随机推荐

  1. python数据结构:numpy

    一. numpy概述 numpy(Numerical Python)提供了python对多维数组对象ndarray(应该是N-dimension array)的支持,具有矢量运算能力,快速.节省空间. ...

  2. Python开发—打包成exe

    pychaim下PyInstaller 打包 python程序 使用PyCharm开发python Pyinstaller打包jieba项目相关解决方案 Python打包成exe 一.安装pyinst ...

  3. adb server version (31) doesn’t match this client (36); killing…

    版权声明:蜜蜂采花酿蜂蜜,奶牛吃草产牛奶. https://blog.csdn.net/codehxy/article/details/52175186 案例1 报错信息如下 C:\Users\lin ...

  4. 关于python读写文件的r+方式的坑

    写脚本的时候需要将文件中的一行修改,我的修改逻辑是,用r+方式打开文件,然后将原文件数据读入一个数组,修改数组的对应元素,在seek(0),然后将数组write进文件 结果: 文件文件末尾总是多出一行 ...

  5. [BZOJ2600] ricehub

    问题描述 乡间有一条笔直而长的路称为"米道".沿着这条米道上 R 块稻田,每块稻田的坐标均为一个 1 到 L 之间(含 1 和 L)的整数.这些稻田按照坐标以不减的顺序给出,即对于 ...

  6. 在Mac电脑上使用NTFS移动硬盘遇到问题

    1.sudo nano/etc/fstab 回车 输电脑密码 2.进入文本插入页面  编入: LABEL=硬盘名字 NONE ntfs rw,auto,nobrowse 3.ctrl + X 退出 选 ...

  7. Cluster基础(一):配置iSCSI服务、编写udev规则、配置并访问NFS共享、部署Multipath多路径环境

    一.配置iSCSI服务 目标: 本案例要求先搭建好一台iSCSI服务器,并将整个磁盘共享给客户端: 虚拟机添加新的磁盘 将新添加的磁盘分区并创建两个逻辑卷 逻辑卷名称分别为:/dev/myvg/isc ...

  8. git commit --amend用法(摘抄)

    适用场景: 比方说,你的代码已经提交到git库,leader审核的时候发现有个Java文件代码有点问题,于是让你修改,通常有2种方法: 方法1:leader 将你提交的所有代码 abandon掉,然后 ...

  9. 我的Podfile如下

    # Uncomment this line to define a global platform for your projectuse_frameworks!(http://www.my516.c ...

  10. 腾讯云服务器centos通过yum安装mysql数据库

    安装mysql有两种: 1-可以使用yum安装, 2-可以自己下载安装包安装mysql, 腾讯云的centos系统自带了yum,所以用yum安装方便点 安装步骤 1-查看yum源中是否有mysql y ...