1. import UIKit
  2. /*
  3. 字典的介绍
  4. 1.字典允许按照某个键访问元素
  5. 2.字典是由两部分组成, 一个键(key)集合, 一个是值(value)集合
  6. 3.键集合是不能有重复的元素, 值集合可以有重复的元素, 键和值是成对出现的
  7. 4.Swift 字典类型是Dictionary 也是一个泛型集合
  8. 5.字典分为  可变字典和 不可变字典
  9. let 修饰不可变字典   var修饰可变字典
  10. */
  11. //1.定义字典
  12. //1>定义不可变字典
  13. //OC   @{@"name":@"summer",@"age":@18}
  14. //系统会自动判断后面[]中存放的键值对,还是一个一个元素
  15. let dict = ["name" : "summer", "age" : 18, "height" : 1.88] as [String : Any]
  16. //2>定义可变字典
  17. //var mutableDict = Dictionary<String, NSObject>() //方式一
  18. //AnyObject: 一般指定类型  NSObject: 一般用于创建对象
  19. //var mutableDict = [String : NSObject]()   //方式二
  20. var mutableDict = [String : AnyObject]() //常用  方式三
  21. //2.对可变字典的基本操作(增删改查)
  22. //2.1> 添加元素
  23. mutableDict["name"] = "summer" as AnyObject?
  24. mutableDict["age"] = 18 as AnyObject?
  25. mutableDict["height"] = 1.88 as AnyObject?
  26. mutableDict["weight"] = 60 as AnyObject?
  27. mutableDict
  28. //2.2> 删除元素
  29. mutableDict.removeValue(forKey: "age")
  30. mutableDict
  31. //2.3>修改元素
  32. //  区别:如果字典中已经有了对应的key, 那么会直接修改原来key中保存的value
  33. //  如果字典中没有对应的key, 那么添加对应的key/value
  34. mutableDict["name"] = "sun" as AnyObject?
  35. mutableDict
  36. mutableDict ["sex"] = "女" as AnyObject?
  37. mutableDict
  38. //2.4> 获取某一个元素
  39. mutableDict["sex"]
  40. //3.遍历字典
  41. //3.1>遍历字典中所有的key
  42. for key in mutableDict.keys{
  43. print(key)
  44. }
  45. //3.2>遍历字典中所以的值
  46. for value in mutableDict.values{
  47. print(value)
  48. }
  49. //3.3>遍历所有的键值对
  50. for (key, value) in mutableDict{
  51. print(key)
  52. print(value)
  53. }
  54. //4.字典的合并
  55. //即使类型一致也不能相加进行合并
  56. //let dict1 = ["name":"summer", "age" : 18] as [String : Any]
  57. //let dict2 = ["sex" : "男", "phoneNumber" : "+86 0393"] as [String : Any]
  58. //
  59. //let resultDict = dict1 + dict2  //写法是错误的
  60. //如果必须合并  那么只能
  61. var dict1 = ["name":"summer", "age" : 18] as [String : Any]
  62. let dict2 = ["sex" : "男", "phoneNumber" : "+86 0393"] as [String : Any]
  63. for (key, value) in dict2{
  64. dict1[key] = value as AnyObject?
  65. }
  66. dict1

Swift 字典 Dictionary基本用法的更多相关文章

  1. Swift 字典的经常用法

    /* * *要正确使用字典,也须要一些条件 * 1.字典键值对的键和值的类型必须明白,能够直接指定.也能够类似数组直接赋值由编译器自己主动识别 * 2,字典必需要初始化 * 3,键的类型必须是能够被哈 ...

  2. [Swift]JSON字符串与字典(Dictionary)、数组(Array)之间的相互转换

    1.JSON字符串与字典(Dictionary)之间的相互转换 import Foundation //JSON字符串转换为字典(Dictionary) func getDictionaryFromJ ...

  3. swift - 字典和集合

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 13.0px Menlo; color: #4dbf56 } p.p2 { margin: 0.0px 0. ...

  4. Swift 03.Dictionary

    字典 key它必须是可哈希的,也就是说,它必须能够提供一个方式让自己被唯一表示出来.Swift的所有基础类型(例如String.Int.Double和Bool)默认都是可哈希的,这些类型都能够用作字典 ...

  5. C#中Dictionary的用法及用途

    Dictionary<string, string>是一个泛型 他本身有集合的功能有时候可以把它看成数组 他的结构是这样的:Dictionary<[key], [value]> ...

  6. Swift字典类

    在Foundation框架中提供一种字典集合,它是由“键-值”对构成的集合.键集合不能重复,值集合没有特殊要求.键和值集合中的元素可以是任何对象,但是不能是nil.Foundation框架字典类也分为 ...

  7. swift字典集合-备

    Swift字典表示一种非常复杂的集合,允许按照某个键来访问元素.字典是由两部分集合构成的,一个是键(key)集合,一个是值(value)集合.键集合是不能有重复元素的,而值集合是可以重复的,键和值是成 ...

  8. C#中Dictionary的用法

    在C#中,Dictionary提供快速的基于兼职的元素查找.他的结构是这样的:Dictionary<[key], [value]> ,当你有很多元素的时候可以使用它.它包含在System. ...

  9. C#中数组、集合(ArrayList)、泛型集合List<T>、字典(dictionary<TKey,TValue>)全面对比

    C#中数组.集合(ArrayList).泛型集合List<T>.字典(dictionary<TKey,TValue>)全面对比 为什么把这4个东西放在一起来说,因为c#中的这4 ...

随机推荐

  1. bit ( 比特 )和 Byte(字节)的关系

    一.存储单位的bit 和 Byte1.bit(比特)bit也就是我们不一定听说过的比特,大名鼎鼎的比特币就是以此命名的.它的简写为小写字母 “b” .作为信息技术的最基本存储单元,因为比特实在太小了, ...

  2. Ubuntu14.043下QT5.5的安装与一点问题

    请注明来自于 http://www.cnblogs.com/usegear/p/5100720.html 1.下载qt-opensource-linux-x86-5.5.0.run(去教育镜像网站下载 ...

  3. 【例题4-6 uva12412】A Typical Homework (a.k.a Shi Xiong Bang Bang Mang)

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 训练编程的题. 原题中没有除0的数据,所以别担心你的代码是因为除0错了. 多半跟我一样. 也是因为没有+eps 就是比如你要算tot ...

  4. States of Integrity Constraints

    States of Integrity Constraints As part of constraint definition, you can specify how and when Oracl ...

  5. [bzoj2186][Sdoi2008]沙拉公主的困惑_数论

    沙拉公主的困惑 bzoj-2186 Sdoi-2008 题目大意:求N!中与M!互质的数的个数. 注释:$1\le N,M\le 10^7$. 想法:显然是求$\phi(M!)$.这东西其实只需要将数 ...

  6. [bzoj4864][BeiJing2017Wc]神秘物质_非旋转Treap

    神秘物质 bzoj-4864 BeiJing-2017-Wc 题目大意:给定一个长度为n的序列,支持插入,将相邻两个元素合并并在该位置生成一个指定权值的元素:查询:区间内的任意一段子区间的最大值减最小 ...

  7. [bzoj2631]tree_LCT

    tree bzoj-2631 题目大意:给定一个n个点的树,每个点的初始权值为1,支持:删边加边(这两个操作同时进行,保证操作之后还是一棵树),路径加,路径乘,查询路径和. 注释:$1\le n,q\ ...

  8. Linux去重命令uniq(转)

    注意:需要先排序sort才能使用去重. Linux uniq命令用于检查及删除文本文件中重复出现的行列. uniq可检查文本文件中重复出现的行列. 语法 uniq [-cdu][-f<栏位> ...

  9. 启动BIOS虚拟化

    启动BIOS虚拟化 学习了:https://jingyan.baidu.com/article/335530daa55d7e19cb41c3c2.html securable.exe下载地址:http ...

  10. codeforces Round #258(div2) C解题报告

    C. Predict Outcome of the Game time limit per test 2 seconds memory limit per test 256 megabytes inp ...