一般我们在开发程序时,只管alloc,不需要管release,因为有ARC帮我们管理。但是在学习时仍需要了解:内存是有限的,在堆区分配了内存后,如果不需要,则要回收,不然内存不够引起崩溃。
所以原则是:有分配,就有回收。但是这个分配有可能分配好几次,那么回收怎么知道回收几次呢?这就是引用计数的作用。创建一个对象时,它自带了这个引用计数。
(1)alloc、new、copy、mutableCopy和retain时,引用计数+1,即retainCount+1;
(2)release时,引用计数retainCount减1;
(3)漏说的assign不会给引用计数+1,因为assign相当于给原来对象指针起了个别名,但是指针地址和指针指向的内容什么的都没有变化;
具体分别,可以见xiaoxuan415315之前的一篇文章:http://blog.csdn.net/xiaoxuan415315/article/details/8061084
(4)autorelease是延迟释放作用,就是执行到这一句时不会立刻释放,而是等整个@autoreleasepool{}执行完再释放。
在这里,还得知:
//以下语句效果一样
ASStudent * zhang=[[ASStudent alloc]init];
ASStudent * zhang=[ASStudent new];
最后,常见的内存管理错误,即内存的分配和释放没有匹配:
-(Complex *)add:(Complex *)aSecond{
Complex * result=[[Complex alloc]init];
result.real=self.real+aSecond.real;
result.imag=self.imag+aSecond.imag;
//下面一定要自动释放一次,因为前面有个alloc。但是在ARC模式下就不需要。
return [result autorelease];
}
//错误写法,因为只释放一次,且NSString alloc那个由于没有指针名,想释放还没法释放
ASStudent * zhang=[[ASStudent alloc]init];
zhang.name=[[NSString alloc]initWithFormat:@"张三"];
[zhang release];
//正确写法
ASStudent * zhang=[[ASStudent alloc]init];
temp=[[NSString alloc]initWithFormat:@"张三"];
zhang.name=temp;
[temp release];
[zhang release];