(1)Autorelease Pool 与函数返回值
如果一个函数的返回值是指向一个对象的指针,那么这个对象肯定不能在函数返回之前进行 release,这样调用者在调用这个函数时得到的就是野指针了,在函数返回之后也不能立刻就 release,因为我们不知道调用者是不是 retain 了这个对象,如果我们直接 release 了,可能导致后面在使用这个对象时它已经成为 nil 了。
为了解决这个纠结的问题, Objective-C 中对对象指针的返回值进行了区分,一种叫做
retained return value
(暂且叫持有型返回值),另一种叫做unretained return value
(非持有型返回值)。前者表示调用者拥有了这个返回值,后者表示调用者未拥有这个返回值
,按照“谁拥有谁释放”的原则,对于前者调用者是要负责释放的,对于后者就不需要了。
按照苹果的命名 convention(惯例),以
alloc, copy, init, mutableCopy 和 new
这些方法打头的方法,返回的都是 retained return value
,例如[[NSString alloc] initWithFormat:]
,而其他的则是unretained return value
,例如 [NSString stringWithFormat:]`。我们在编写代码时也应该遵守这个 convention。
self.property = nil;
实际上也相当于执行了一次[_property release];_property = nil
的操作!(MRC下可以尝试这样做下,哈哈哈)
Q:(1)属性关于内存管理的默认的修饰符是unsafe_unretained?
答:在以前可能是,但现在默认的属性修饰符是strong,这种默认与变量标识符的默认是一致的。
(2)MRC时代属性修饰符有哪些?ARC时代添加了哪些属性修饰符?
答:MRC时代:
assign/retain/copy
;ARC时代:assign/weak/strong/retain/copy
。
(3)变量标识符是何时引入的?还是一开始就有?
(4)Block作为属性时的修饰符是什么?MRC时代、ARC时代对Block的修饰有影响吗?
答:用copy。不同时代不同类型的block存储位值稍微有些差别;
(5)内存泄漏的类型有哪些?
Leaked memory
: Memory unreferenced by your application that cannot be used again or freed (also detectable by using the Leaks instrument).
Abandoned memory
: Memory still referenced by your application that has no useful purpose.
Cached memory
: Memory still referenced by your application that might be used again for better performance.
如果Person类 是被第一次访问,会进行类加载,类加载详细过程我们后续再谈;OC中的变量在内存中的使用分布。