内存管理(三)

(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。

MRC(1)
MRC(2)
MRC(3)
ARC

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中的变量在内存中的使用分布。

你可能感兴趣的:(内存管理(三))