NSMutableArray和NSMutableDictionary的底层实现

NSMutableArray

数据结构
  • _used 计数
  • _list 缓冲区指针
  • _size 缓冲区大小
  • _offset 缓冲区里的数组的第一个元素索引
    _NSArrayM使用的底层实现主要是“环形缓冲区”,这个数据结构相当简单,只是比常规数组或缓冲区复杂一点。环形缓冲区的内容能在到达任意一端时绕向另一端。
插入/删除

环形缓冲区在未满的情况下插入或删除数据,不会要求移动任何内存。在任意一端插入或者删除,只是修改offset参数,不需要移动内存。访问数组元素的时候是通过index+offset来定位内存地址的。插入数组中间时,环形结构会根据最少移动内存的指针插入(_NSArrayM试着去最小化内存的移动,因此会移动最少的一边元素)。

与此类似,在删除头部元素的时候,也只是需要修改offset。在删除中间元素时,也只是会移动最少的一边元素。

与C风格数组对比

NSMutableArray是一个高级抽象数组,解决了C风格数组对应的缺点(C数组插入的时候都会移动内存,不是O(1)),用到了环形缓冲区数据结构来处理内存移动的损耗。而NSMutableArray在任意一端插入或删除的时候有固定时间的性能,而在中间插入/删除的时候都会试着去移动最小化内存。

优化

环形缓冲区的数据结构如果是连续数组结构,在扩容的时候需要移动大量内存,从这个角度看,用链表实现环形缓冲更好。

NSMutableDictionary

数据结构
  • _base
  • _count
  • _capacity 扩充阈值
  • _bucketsNum
  • _marker
  • _context
  • _deletes
  • _xflags
  • _keys
  • _values
底层实现

NSDictionary底层其实是一个哈希表。根据数据结构可以发现NSDictionary内部使用了两个数组分别来保存keys和values。
NSDictionary采用连续存储的方式存储键值对,并由两个数组分别存储。key哈希出来数组的下标地址,同样的这个地址对应到values数组的下标,就是匹配到的值。因此keys和values这两个数组的长度一致才能保证匹配到数据。内部结构还有个_capacity表示当前列表的扩充阈值,当count数量达到这个长度就扩容。

NSDictionary设置的key和value,key值会根据特定的hash函数算出建立的空桶数组,keys和values同样多,然后存储数据的时候,根据hash函数算出来的值,找到对应的index下标。如果下标已有数据,开放定址法后移动插入。如果空桶数组的数量达到数据阈值,这个时候就把空桶数组扩容,然后重新哈希插入。

这样把一些不连续的key-value值插入到能建立起关系的hash表中,当我们查找的时候,key根据哈希值算出来,然后根据索引,直接index访问hash表的hash和values,这样查询速度就可以和连续线性存储的数据一样接近O(1)了,只是占用空间有点大。删除的时候,根据marker标记逻辑上的删除,除非NSDictionary内存被移除。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345