ios内存管理笔记(一)
objc提供了两种内存管理的方法
1,MRR manual retain-release
2, ARC Automatic Reference Counting
基本的内存管理法则:
1, 拥有任何创建的对象,例如new alloc copy等
2, 可以通过retain来获得对象的控制权
3, 当不再需要对象时必须释放
4, 不能释放没有控制权的对象
上面的例子中使用了alloc来获取了对象的控制权,在失去引用之前必须放弃拥有权。但是如果使用release,那么对象就会在return之前被释放掉,最终返回无效的对象。此处使用autorelease表示你将放弃此控制权但是允许在对象被dealloc之前调用函数使用其返回值。
你也可以使用下面的方法,即不alloc来获取拥有权而是直接返回值也是可以的,例如:
- (NSString *)fullName{
NSString *string = [NSString initWithFormat:@"%@ %@", self.firstName, self.lastName];
return string;
}
但是下面这种方法就是错误的
上面的这种方法,调用函数并不拥有此return的string的值,因此调用函数没有理由去释放返回的string,因此就会造成内存泄漏。所谓的拥有就是说使用alloc new retain等来获得其控制权。
执行dealloc来放弃拥有权
dealloc的调用时机:在对象不再有拥有者并且内存回收时会调用这个方法。dealloc会释放对象的内存并处理其所有的资源包括任何实例对其的所有权
当程序结束后,有可能不会为对象发送dealloc消息。因为进程内存在程序退出后会被自动清除,这样做更为方便。
避免为正在使用的object调用dealloc
使用autorelease pool
Autorelease pool只对于在其作用域内显示使用了autorelease的对象起作用
提供了一种机制,在取消对象时防止立即被销毁。一般不需要创建自己的autorelease pool,但是有一些情况必须或者还是很有必要来创建自己的autorelease pool
在autorelease pool块尾,凡是在块儿内有收到autorelease message的对象都会被发送一个release message
可以嵌套使用
三种情况需要创建自己的autorelease pool
1,基于命令行的程序
2,loop中有过多的临时变量
3,启动子线程
启动线程如果使用posix api而不是NSThread,那么除非cocoa当前项目是多线程否则不能使用cocoa。可以使用ismultithreaded方法来判断是否是多线程