关于 Objective-C iVar 的一点说明

Class A:

@interface ClassA : NSObject{
}
@property(nonatomic, retain) Foo* foo;
@end


Class B:

@interface ClassB  : NSObject{
    Foo* foo;
}
@property(nonatomic, retain) Foo* foo;
@end


上面两个类的不同是:第二个类包含一个名字为"foo"的 ivar

如果在类的实现部分包含了"@synthesize foo;",

并且用了比较新的编译器(好像是从 4.2 开始的),

对于第一个类,编译器会自动为类添加一个合适的ivar,

你可以直接用foo,就像定义了foo这个成员变量一样。
ivar 的 synthesis 机制依赖于 Objective-C 的“修复脆弱基类的特性”。
在大部分编译型语言中,ivar 的访问是通过“对象地址 + ivar 偏移量”的方式,
子类中的 ivar 需要在基类 ivar 的后面,这样子类必须知道基类对象的大小才可以计算出自身 ivar 的开始地址。
当改变基类的大小时,比如增加或者减少 ivar,就必须重新编译所有子类。
Objective-C 解决“脆弱基类”的方式是:将所有 ivar 的大小作为一项元数据,存储到类的元信息中,并且在运行时进行设置。
这样可以通过“对象地址+基类大小+ivar偏移量”的方式来计算相应的ivar 地址,并访问对应的ivar。
关于“ivar synthesis”的底层机制依赖于编译器,总之编译器会调整 ivar 区域,以达到动态添加 ivar 的目的。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值