iOS底层探究-isa结构分析

前言

相信大部分多年工作经验的iOS开发者知道了OC的对象本质上是一个基于C语言封装的结构体。这个结构体有一个成员叫isa,它指向这个对象的类对象,那么今天我就来深入探究下这个isa成员。

验证对象是否真的是结构体,结构体是否有isa成员。

1.我们创建一个工程,在man.m文件内定义一个继承NSObject的对象LGPerson,里面放一个NSString属性name。如下图

main.m

2.用Clang编译器将刚刚编写的main.m文件编译成C++文件。

用终端cd到刚刚创建的工程根目录下,然后执行clang -rewrite-objc main.m -o main.cpp把目标文件编译成c++文件

编译成C++

然后我们打开main.cpp文件,搜索LGPerson结果如下,我们发现了LGPerson真的是个结构体,下图红框标注iOS底层声明了一个objc_object结构体LGPerson,我们记住这个objc_object结构体名称。
LGPerson

3.我们在main.m文件导入头文件#import <objc/objc.h>,按住command鼠标左键点击头文件跳转进去objc源码,然后我们搜索objc_object,发现如下图所示iOS底层对象真的是结构体封装,并且真的里面有一个isa

objc文件源码

isa里面有哪些信息,是不是真的有类对象,还有没有其他信息,我们接下来看看

1.我们继续打开之前博客提到的objc源码工程,我们看到红框里面isa是一个union联合体。

结构体(struct)中所有变量是“共存”的——优点是“有容乃大”, 全面;缺点是struct内存空间的分配是粗放的,不管用不用,全分配。
联合体(union)中是各变量是“互斥”的——缺点就是不够“包容”; 但优点是内存使用更为精细灵活,也节省了内存空间。

isa结构

大家可以具体了解下联合体概念,接下来我们点击联合体isa里面的ISA_BITFIELD看到这是一个宏定义
isa

那么上面宏定义里面这些nonpointer :1是代表什么呢?
nonpointer:表示是否对 isa 指针开启指针优化 0:纯isa指针,1:不止是类对象地址,isa 中包含了类信息、对象的引用计数等。
has_assoc:关联对象标志位,0没有,1存在。
has_cxx_dtor:该对象是否有 C++ 或者 Objc 的析构器,如果有析构函数,则需要做析构逻辑, 如果没有,则可以更快的释放对象。
shiftcls:存储类指针的值。开启指针优化的情况下,在 arm64 架构中有 33 位用来存储类指针,上面图中74行# elif __x86_64__表示在x86_64(模拟器,Mac端)内核下占44位。
magic:用于调试器判断当前对象是真的对象还是没有初始化的空间。
weakly_referenced:志对象是否被指向或者曾经指向一个 ARC 的弱变量,
没有弱引用的对象可以更快释放。
deallocating:标志对象是否正在释放内存。
has_sidetable_rc:当对象引用技术大于 10 时,则需要借用该变量存储进位。
extra_rc:当表示该对象的引用计数值,实际上是引用计数值减 1, 例如,如果对象的引用计数为 10,那么 extra_rc9。如果引用计数大于 10, 则需要使用到下面的 has_sidetable_rc
isa占8字节64位,第一个nonpointer :1,表示从右开始长度为1的字节位数信息为nonpointer
同理第四排 shiftcls :44表示从第4位开始往左长度为44位存储类指针
好了,看完资料我们了解了isa里面第4位到47位存储了类指针,接下来就是验证环节了,注意我们是在模拟器运行,如果是真机运行那么shiftcls就只占33位了。
image.png

我们打个断点然后在控制台按照红框的指令打印LGPerson对象p的数据,最后拿到p的首内存地址数据0x001d800100002205(也就是isa字段),然后我们通过输入p/t LGPerson.class打印LGPerson类所存储的2进制地址。
isa内4-47位数据和LGPerson类存储指针2进制地址

我们发现一个惊人的事实,那就是我红框内的数据一模一样!从右起第4位开始到第47位中间44位数据一模一样!这个完全验证了我们上面贴图的isa内的shiftcls : 44;的定义。

结论

对象其实是底层封装好的结构体,结构体内第一个成员为isa(这个对象所继承的类指针),其中该类指针放在isa的第4-47位(x86_64 模拟器)或第4-37位(arm64 真机)

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