今天我们继续来探究类的原理分析
断点打印P指令
cache_t jump进入
bucket_t jump进入
下面通过LLDB去验证方法的存储
几次失败的尝试
再看下源码
继续尝试
为什么会是空的值呢?
因为我用的是模拟器,所以走的是下面的代码
继续看源码
使用sel输出
(lldb) p $13.imp(nil,pClass)
(IMP) $15 = 0x0000000100003c80 (HLObjcBuild`-[HLPerson saySomething])
接下来我们根据源代码
可以自己定义
此处为互斥结构
buckets
数组取值
p 6 = xxxxx -> p $3+1 指针内存平移取值
_bucketsAndMaybeMask的使用
不同架构选择
内存地址打印
0b0000000000000000000000000000000100000000011100001001100110110000
左边为高地址,右边为低地址
(lldb) x p ->内存
0x100744a80: c9 84 00 00 01 80 1d 01 00 00 00 00 00 00 00 00 ................
0x100744a90: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
大端模式从左往右 读取8个字节 0x
00 00 84 c9
小短模式从右到左 读取8个字节 0x c9 84 00 00
3/4 扩容 -> 负载因子为0.75
1、空间利用率最高
2、能有效避免哈希冲突碰撞(底层的链表及红黑树频率)
insert
bt-查看整个的堆栈
frame #1: 0x000000010031374a libobjc.A.dyliblog_and_fill_cache(cls=OS_dispatch_data, imp=(libdispatch.dylib-[OS_dispatch_data dealloc]), sel="dealloc", receiver=0x00000001007171c0, implementer=OS_dispatch_data)(), objc_selector*, objc_object*, objc_class*) at objc-runtime-new.mm:6305:16
补充
Value 为什么等于7呢?
3->7 是因为发生了类似的扩容
insert函数
添加打印语句
printf("=== %s - %p - %p \n",(char*)sel,imp,receiver);
跟踪HLPerson