NSDictionary
是使用hash
表来实现key
和value
之间的映射和存储的,hash
函数设计的好坏影响着数据的查找的访问效率。数据在hash
表中分布的越均匀,其访问效率越高。而在Objective-C
中,通常是利用NSString
来作为键值,其内部使用的hash
函数也是通过使用NSString
对象作为键值来保证数据的各个节点在hash
表中的均匀分布。
NSDictionary内部结构
NSDictionary
使用NSMapTable
实现,NSMapTable
同样是一个key-value
的容器
NSMapTable
是一个哈希+链表的数据结构,因此在NSMapTable
中插入或者删除一对对象时,寻找的时间是O(1)+O(m),m最坏可能为n;
- O(1):为对
key
进行hash
得到bucket
的位置; - O(m):遍历该
bucket
后面冲突的value
,通过链表连接起来;
网友评论