PHP转Go系列:map映射

映射的定义

初识映射会很懵,因为在PHP中没有映射类型的定义。其实没那么复杂,任何复杂的类型在PHP中都可以用数组表示,映射也不例外。

$array['name'] = '平也';
$array['sex'] = '1';
$array['age'] = '10';

//output
Array
(
    [name] => 平也
    [sex] => 1
    [age] => 10
)

映射其实就是有key有value的数组,在Go中的赋值也很类似,但需要提前声明该映射类型的键与值的类型,确保所有的键和值的赋值类型统一,否则会报错。

array := make(map[string]string)
array["name"] = "平也"
array["sex"] = "1"
array["age"] = "10"
fmt.Print(array) //output map[age:10 name:平也 sex:1]

在PHP中还有一种初始化数组的方法,就是将所有要存储的键与值赋值给变量。

$array = [
    'name' => '平也',
    'sex' => '1',
    'age' => '10'
];

在Go中也有类似的初始化方法,但切记统一键与值的数据类型。

array := map[string]string{
    "name": "平也",
    "sex":  "1",
    "age":  "10",
}

映射的遍历

在PHP中其实就是遍历数组的操作,foreach即可。

$array = [
    'name' => '平也',
    'sex' => '1',
    'age' => '10'
];

foreach ($array as $key => $value) {
    print_r($array);
}

//output
Array
(
    [name] => 平也
    [sex] => 1
    [age] => 10
)
Array
(
    [name] => 平也
    [sex] => 1
    [age] => 10
)
Array
(
    [name] => 平也
    [sex] => 1
    [age] => 10
)

在Go中也可以像遍历数组那样遍历map,依然使用range关键字。

array := map[string]string{
    "name": "平也",
    "sex":  "1",
    "age":  "10",
}
for v, k := range array {
    fmt.Print(k, v)
}

上篇文章讲到遍历时可以通过下划线来忽略键或值,如果只遍历键,下划线也可以省略。

array := map[string]string{
    "name": "平也",
    "sex":  "1",
    "age":  "10",
}
for k := range array {
    fmt.Print(k)
}
//output sexagename

映射的取值

PHP中可以直接通过读数组的key来取值。

$array = ['name' => 'pingye'];
echo $array['name']; //output pingye

在Go中的操作是一样的,与PHP不同的是,如果取了不存在的key,Go中默认输出空值,在PHP中就会产生warning警告。

array := map[string]string{
    "name": "pingye",
    "sex":  "1",
    "age":  "10",
}
fmt.Print(array["name"]) //pingye

映射元素的删除

在PHP中的unset可以删除任何你想删除的数组元素,非常好用。

$array = [
    'name' => '平也',
    'sex' => '1',
    'age' => '10'
];
unset($array['name']);
print_r($array);

//output
Array
(
    [sex] => 1
    [age] => 10
)

在Go中通过delete函数来删除map中的元素。

array := map[string]string{
    "name": "pingye",
    "sex":  "1",
    "age":  "10",
}
delete(array, "name")
fmt.Print(array) //output map[age:10 sex:1]

清空map元素

在PHP中好像从来没有注意过是否把数组清空,很抱歉,我能想到的清空数组方法就是把空数组赋值给它。

$array = [
    'name' => '平也',
    'sex' => '1',
    'age' => '10'
];
$array = [];
print_r($array);
//output
Array
(
)

然而,在Go中也没有提供清空map的函数,重新make一个map就行了,原来的map会被Go的垃圾回收机制清除掉,甚至比写一个清空的函数效率还高。以上是PHP与Go在map映射方面的区别于联系,如果感兴趣可以自行了解尝试。

原文地址:https://www.cnblogs.com/enochzzg/p/11022940.html

时间: 2024-10-18 06:55:38

PHP转Go系列:map映射的相关文章

NHibernate3剖析:Mapping篇之集合映射基础(4):Map映射

系列引入 NHibernate3.0剖析系列分别从Configuration篇.Mapping篇.Query篇.Session策略篇.应用篇等方面全面揭示NHibernate3.0新特性和应用及其各种应用程序的集成,基于NHibernte3.0版本.如果你还不熟悉NHibernate,可以快速阅读NHibernate之旅系列文章导航系列入门,如果你已经在用NHibernate了,那么请跟上NHibernate3.0剖析系列吧. NHibernate专题:http://kb.cnblogs.com

map——映射(message.cpp)

信息交换 (message.cpp) [题目描述] Byteland战火又起,农夫John派他的奶牛潜入敌国获取情报信息. Cow历尽千辛万苦终于将敌国的编码规则总结如下: 1 编码是由大写字母组成的字符串. 2 设定了密字.加密的过程就是把原信息的字母替换成对应密字. 3 一个字母有且仅有一个对应密字,不同字母对应不同密字. 如今,Cow终于获取了敌国发送的一条加密信息和对应的原信息.Cow如下破解密码:扫描原信息,对于原信息中的字母x,找到它在加密信息中的对应大写字母y,且认为y是x的密字.

POJ2503——Babelfish(map映射+string字符串)

Babelfish DescriptionYou have just moved from Waterloo to a big city. The people here speak an incomprehensible dialect of a foreign language. Fortunately, you have a dictionary to help you understand them.InputInput consists of up to 100,000 diction

ZOJ 3644 Kitty's Game dfs,记忆化搜索,map映射 难度:2

http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4834 从点1出发,假设现在在i,点数为sta,则下一步的点数必然不能是sta的因数,所以不会形成环,只需从1直接走,走到n即可. 但是如果这样的话时空复杂度就都是nk,明显不满足题意,而这个时候我们可以想到,每个状态都必然是k的约数,(点数不是k的约数的节点不在路上,可以无视),而约数的个数也就k^0.5个,可以直接用map映射,这样时空复杂度都是n*k^0.5,可以解出答案

UVA12096 - The SetStack Computer(set + map映射)

UVA12096 - The SetStack Computer(set + map映射) 题目链接 题目大意:有五个动作: push : 把一个空集合{}放到栈顶. dup : 把栈顶的集合取出来,在入栈两次. add : 出栈两次,把第一个集合作为一个元素放入第二个集合中,再将第二个集合入栈 union: 出栈两次,取这两个集合的并集,将结果入栈. intersect: 出栈两次,取这两个集合的交集,将结果入栈. 每次执行动作后还需要输出目前栈顶集合的元素个数. 解题思路:这题可以用栈和se

探讨C++中的Map映射机制

概述 从MFC到ATL,充斥着Map映射机制,似乎没有了这个Map机制,就玩不转啦.在WebBrower控件中,也存在着事件映射:在COM中,在IDispatch中也存在着自定义的函数映射. 以前,只要一谈到映射机制,总是让我闻风丧胆,退而求自保,暂且如此而已,记住就可以啦.现在想来,只要是跨不去过的坎,若没有认真面对和解决,那就永远无法逾越,成为心中永远的痛.最终,只能作茧自缚而唯唯诺诺.既然老天爷,又给了我一次机会,那我就好好抓住这次机会啦. 轰轰烈烈的开场白讲完了,让我们回归主题:"映射机

HDU 4941 Magical Forest(map映射+二分查找)杭电多校训练赛第七场1007

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4941 解题报告:给你一个n*m的矩阵,矩阵的一些方格中有水果,每个水果有一个能量值,现在有三种操作,第一种是行交换操作,就是把矩阵的两行进行交换,另一种是列交换操作,注意两种操作都要求行或列至少要有一个水果,第三种操作是查找,询问第A行B列的水果的能量值,如果查询的位置没有水果,则输出0. 因为n和m都很大,达到了2*10^9,但水果最多一共只有10^5个,我的做法是直接用结构体存了之后排序,然后m

【组队赛#5】BNU 4291 Arbitrage? (floyd最短路 map映射)

[题目链接]click here~~ [题目大意]去多个国家旅游,给定国与国之间汇率的转化率,如果从起点出发最后回到起点,有收益则符合,否则不符合 [解题思路] 判一次环,用floyd计算距离最短的而且转换率最大的,map<string ,int >映射  <字符串--点> 代码 /* BNUOJ 4291 Arbitrage? Author :HRW 判一次环,用floyd计算距离最短的而且转换率最大的 map<string ,int >映射 <字符串--点&g

PAT甲题题解-1022. Digital Library (30)-map映射+vector

博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6789235.html特别不喜欢那些随便转载别人的原创文章又不给出链接的所以不准偷偷复制博主的博客噢~~ 题意:给出n本书的id.名称.作者.多个关键词.出版社.出版年然后给出m个查询,每个查询包含查询的种类.对应的内容针对每个查询,让你输出所有符合的书的id,从小到大排序,没有的话则输出No Found 首先把每个book的信息都读取处理好,然后按照id排个序