//
// main.m
// AutoreleasePoolTemp
//
// Created by maqianli on 2016/10/31.
// Copyright © 2016年 maqianli. All rights reserved.
//
#import <Foundation/Foundation.h>
@interface MQLTest : NSObject
@end
@implementation MQLTest
-(instancetype)init{
self = [super init];
if (self != nil) {
}
return self;
}
-(void)dealloc{
//[super dealloc];
NSLog(@"MQLTest:dealloc");
}
@end
void fun(){
/*
说明:添加到自动释放池的目的,是在自动释放池自己释放时,才将添加到里面的对象释放,是一种延时释放。
autorelease的调用,不会引起引用计数的增加。
ARC正常情况下,创建的强引用变量会在超出其作用域的时候被释放掉。而如果你的函数写的很长,在你函数运行过程中出现很多中间变量,占据了大量的内存,怎么办?
用@autoreleasepool。在@autoreleasepool中创建的变量,会在@autoreleasepool结束的时候执行一次release,进行释放,不必等到函数结束时才释放。其实@autoreleasepool就相当于一层作用域。
*/
/*
//第一种:在非ARC下,使用代码创建自动释放池,手动将对象添加到自动释放池中
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc]init];
MQLTest *test = [[[MQLTest alloc]init]autorelease];
[pool release];
*/
/*
//第二种:在非ARC下,利用编译器创建自动释放池,但仍需手动将对象添加到自动释放池中
@autoreleasepool {
MQLTest *test = [[[MQLTest alloc]init]autorelease];
}
*/
/*
//第三种:在ARC下,利用编译器创建自动释放池,在{}中创建的test对象,当超出自动释放池块时,此时超过test有效范围,所以强引用对象被释放
@autoreleasepool {//这里的自动释放池,只是相当于一层作用域。有人认为ARC下已经失去了自动释放池原有的作用(因为无法将对象加入池中,不知道为什么ARC还保留着?其实,系统底层方法中有autorelease的调用,毕竟最终都需要转成非ARC代码);去掉@autoreleasepool,只保留{},效果一样。
MQLTest *test = [[MQLTest alloc]init];
}
*/
/*
//第四种:在ARC下,赋值给强引用对象,可以看到:当函数将要结束时,会调用对象的dealloc方法,所以得知强引用对象,在超过其有效范围时,会被释放掉。
MQLTest *test = [[MQLTest alloc]init];
*/
/*
//第五种:在ARC下,赋值给弱引用对象,可以看到:当赋值结束时,就会调用对象的dealloc方法,所以得知,创建的对象,只有赋值给强引用对象,引用计数才生效,否则会被立即释放掉。
__weak MQLTest *test = [[MQLTest alloc]init];
*/
}
int main(int argc, const char * argv[]) {
fun();
return 0;
}