1.什么是内存管理
程序在运行过程中管理内存分配的过程,当需要内存的时候就申请一片内存空间,不需要的时候就释放掉。
2.如何去管理内存
站在分配对象拥有权的角度来操作内存。
3.内存管理的两种方法
a.MRR(Manual Retain Release)手动管理,实现的机制:reference counting引用计数机制
b.ARC(Automatic Reference Counting)自动引用计数,实现机制,系统在程序编译阶段自动添加了释放对象的方法。
4.引起内存错误的两种情况
a.释放掉一个正在使用的对象
b.不用的对象没有释放掉,导致内存错误
5内存管理的基本原理
a.使用alloc new copy mutableCopy开头的方法创建的对象就由拥有权,就应该负责释放
b.表示自己创建的对象,但是又想获得这个对象的拥有权,可以使用retain(属性的setter方法和init方法)
c.当一个对象不再使用了,就应该释放掉自己的那份拥有权
d.不能去释放一个自己没有拥有权的对象
6.可以使用autorelease来实现延迟释放,使用场合(在一个方法里面返回一个对象)
- (NSString *)fullName{
NSString *string = [[[NSString alloc] initWithFormat:@"%@:%@",self.name, self.address] autorelease];
return string;
}
- (void)printFullName{
NSString *temp = [self fullName];
NSLog(@"%@", temp);
}
7.release 和 autorelease
a. release 是立刻释放 autorelease是延迟释放
b. release的优点:可以立刻释放内存
autorelease的优点:可以延迟释放,操作方便,出错概率小。 在某一段时间内内存是增加的。
c. 企业里面的使用习惯:autorelease
8.如何释放掉一个对象本身拥有的资源
通过在类的实现文件里面重写父类的dealloc方法来实现释放一个对象本身拥有的资源
a.dealloc方法是当这个对象的拥有者为0,那么系统会自动调用对象的dealloc方法,不能主动去调用
b.在dealloc方法里面,先释放掉自己对象的拥有权,然后再调用【super dealloc】释放自己
9.实际操作
a.尽量使用访问器方法来操作属性变量(self.name)
b.在dealloc方法里面尽量不要使用访问器方法
10.防止retain cycle
A对象里面用有B对象,B对象里面拥有A对象,当A要释放掉自己的时候,必须等B对象释放掉自己对A的拥有权
B对象要释放掉自己的时候,必须等A对象释放对自己的拥有权,所以两者都释放不了
解决方案:
大的强引用小的(retain strong) 小的弱引用大的(weak)
11.不能使用retainCount去查看一个对象的拥有者,只能确保代码是按照内存管理的原理来操作的就OK了
12.重写setter方法
-(void)setName:(NSString *)name{
if (_name != name) {
[_name release];
_name =[name retain]; //property( ,strong)重写的时候必须加
}
}
13.autorelease pool三种情况要写
a.当创建一个非UI的工程,需要自己写
b.在一个循环里面会产生大量的临时对象
c.开辟一个新的线程