文档章节

GO map相关操作

汤汤圆圆
 汤汤圆圆
发布于 2018/09/25 17:48
字数 444
阅读 8
收藏 0
Go
package main

import (
	"fmt"
	"sort"
)

type Stu struct{
	Name string
	Age int
	Address string
}

func main() {
	var m map[string]string
	m = make(map[string]string, 10)
	m["a"] = "wangwu"
	m["b"] = "zhangsan"
	fmt.Println(m)

	m2 := make(map[string]string, 3)
	m2["a"] = "a"
	m2["b"] = "b"
	fmt.Println(m2)

	m3 := map[string]string{
		"n1" : "x",
		"n2" : "y",
		"n3" : "z",//最后一个逗号不能去掉
	}
	m3["a"] = "a"
	fmt.Println(m3)

	//二维map
	var m4 map[string]map[string]string;
	m4 = make(map[string]map[string]string, 2) //给分配大小
	m4["t1"] = make(map[string]string, 3) //一维也是一个map
	m4["t1"]["n1"] = "t1n1"
	m4["t1"]["n2"] = "t1n2"

	m4["t2"] = make(map[string]string, 2)
	m4["t2"]["n1"] = "t2n1"
	m4["t2"]["n2"] = "t2n2"
	fmt.Println(m4)

	//map curd cu看上面
	delete(m4, "t1")
	//make(map[string]map[string]string) //清除所有的key
	fmt.Println(m4)
	val,ok := m3["t1"] //如果存在ok是 true,否则false, val 为对应的值
	if ok {
		fmt.Printf("t1存在 val为 %v\n", val)
	} else {
		fmt.Println("t1不存在")
	}
	
	//遍历,求长度也是用len(map)方法
	for i,v := range m4 {
		for j,val := range v {
			fmt.Printf("i=%v, j=%v, val=%v\n", i, j, val)
		}
	}

	//map 切片
	var mapSlice []map[string]string
	mapSlice = make([]map[string]string, 1) 
	ms1 := map[string]string{
		"name" : "zhangsan",
		"age"  : "10",
	}
	mapSlice[0] = ms1
	ms2 := map[string]string{
		"name" : "lisi",
		"age"  : "20",
	}
	mapSlice = append(mapSlice, ms2)
	fmt.Println(mapSlice)

	//map排序,key放入切片,对切片排序;然后取值
	m5 := map[int]string{
		1:"av",
		2:"bv",
		3:"cv",
	}
	fmt.Println(m5)
	var keys []int;
	for k,_ := range m5 {
		keys = append(keys, k)
	}
	sort.Ints(keys)
	for _,v := range keys {
		fmt.Printf("key k=%v, v=%v\r\n", v, m5[v])
	}

	//map是引用传值
	test(m5)
	fmt.Println(m5) //[1:av 2:bv 3:233333]

	//map的value一般是用结构体
	m6 := make(map[string]Stu, 2)
	stu1  := Stu{"tom", 18, "北京"}
	stu2  := Stu{"王五", 28, "武汉"}
	m6["no1"] = stu1
	m6["no2"] = stu2

	for k,v := range m6 {
		fmt.Printf("学生号%v,name:%v,age:%v,address:%v\n", k, v.Name, v.Age, v.Address)
	}
}

func test(m map[int]string) {
	m[3] = "233333"
}

© 著作权归作者所有

汤汤圆圆

汤汤圆圆

粉丝 11
博文 82
码字总数 26104
作品 0
昌平
程序员
私信 提问
【Nginx探究系列二】Nginx配置篇之客户Nginx白名单访问配置

一、简介 在通常情况下,使用 nginx 基于 ip 限制访问请求频率等限制内容,我们会需要对特定ip进行限制排除操作,因此本文引入了基于nginx geo 与 nginx map 进行此类情景相关配置; 在没有人...

开源中国首席撸码官
2015/10/10
3.6K
0
Apache commons类库阅读笔记

commons-io --------Start--------- FilenameUtils 文件名称一些操作,如判断文件扩展名称等 FileUtils 文件工具类 IOUtils 主要提供了IO常见操作 Stream 转换,关闭Stream等操作 FileUtils文...

lis1314
2016/05/10
189
0
C++ STL map补坑

先讲下我的基本需求:选用C++ STL map容器用于存储关联数据,我的Key为std::string类型,Value为自定义类指针;这里假设为Object*; 其实踩到的坑很简单,就是用了map的下标操作和insert操作...

熊友良
2015/08/29
237
0
cocos2d-x3.0中数据类型vector,map、value

在3.0中,已经不再使用以前的ccarray,ccdictionary,ccint等从以前的oc继承过来的数据类型,转而加入了自己的数据结构,更加符合c++的开发习惯和思考模式,其中就包括了vector,map和val...

_子墨
2014/08/13
677
0
clojure 新手指南(14):Hash-Maps ,Array-Maps & Sorted...

hash-map 创建 在clojure中,哈希表是最通用的一种Map,和java中的HashMap一样,它们在处理大量数据方面效率非常高,但是不保证顺序。我们可以使用函数hash-map来创建哈希表: =>(hash-map :...

凯奥斯
2013/07/18
770
0

没有更多内容

加载失败,请刷新页面

加载更多

java数据类型

基本类型: 整型:Byte,short,int,long 浮点型:float,double 字符型:char 布尔型:boolean 引用类型: 类类型: 接口类型: 数组类型: Byte 1字节 八位 -128 -------- 127 short 2字节...

audience_1
21分钟前
2
0
太全了|万字详解Docker架构原理、功能及使用

一、简介 1、了解Docker的前生LXC LXC为Linux Container的简写。可以提供轻量级的虚拟化,以便隔离进程和资源,而且不需要提供指令解释机制以及全虚拟化的其他复杂性。相当于C++中的NameSpa...

Java技术剑
22分钟前
2
0
Wifiphisher —— 非常非常非常流氓的 WIFI 网络钓鱼框架

编者注:这是一个非常流氓的 WIFI 网络钓鱼工具,甚至可能是非法的工具(取决于你的使用场景)。在没有事先获得许可的情况下使用 Wifiphisher 攻击基础网络设施将被视为非法活动。使用时请遵...

红薯
51分钟前
36
1
MongoDB 4 on CentOS 7安装指南

本教程为CentOS x86_64 7.x操作系统下,MongoDB Community x86_64 4.2(GA)安装指南。 安装方式一:yum repo在线安装 [此方式较为简单,官方推荐] Step1:新建MongDB社区版Yum镜像源。 # vim ...

王焱君
53分钟前
3
0
go-micro 入门教程1.搭建 go-micro环境

微服务的本质是让专业的人做专业的事情,做出更好的东西。 golang具备高并发,静态编译等特性,在性能、安全等方面具备非常大的优势。go-micro是基于golang的微服务编程框架,go-micro操作简单...

非正式解决方案
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部