OC内存管理机制

2016-02-15  本文已影响217人  那笑容不是为我

一.基本原理

为什么要进行内存管理?

由于移动设备的内存有限,所以每个App所占的内存空间也是有限的,当App所占用的内存较多时,系统就会发出内存警告,,为了节省内存的使用

当对象不再使用内存时,需要及时的对内存进行回收

管理范围:任何继承与NSObject的对象,对其他的基本数据类型无效.

对象的基本结构:

引用计数器:用来保存当前对象,有几个东西在使用(数字);

引用计数器的作用:用来判断对象是否应该回收内存空间,当引用计数器为0时,此时需要回收对象的内存空间

引用计数器的操作:

retain: 引用计数器 +1
release: 引用计数器 -1

retainCount:得到引用计数器的值

对象销毁

当一个对象的引用计数器为0时,那么它将被销毁,其占用的内存被系统回收

当对象被销毁时,系统会自动向对象发送一条dealloc消息,一般会重写dealloc方法,在这里释放相关的资源,dealloc就像是对象的“临终遗言”。一旦重写了dealloc方法就必须调用[super dealloc],并且放在代码块的最后调用(不能直接调用dealloc方法)
一旦对象被回收了,那么他所占据的存储空间就不再可用,坚持使用会导致程序崩溃(野指针错误)

内存管理原则

(一)原则
只要还有人在使用某个对象,那么这个对象就不会被回收;
只要你想使用这个对象,那么就应该让这个对象的引用计数器+1;
当你不想使用这个对象时,应该让对象的引用计数器-1;
(二)谁创建,谁release
(1)如果你通过alloc,new,copy来创建了一个对象,那么你就必须调用release或者autorelease方法
(2)不是你创建的就不用你去负责
(三)谁retain,谁release
只要你调用了retain,无论这个对象时如何生成的,你都要调用release

Autorelease

#pragma mark ----- autorelease ------
        
        //创建对象后,如果想让对象在出自动释放池的时候,调用dealloc方法,那么需要在后面加上autorelease;
        //Person *person = [[Person new] autorelease];//引用计数1
        
        
        //此时person的引用计数为0,会调用dealloc方法
        //[person release];
//        
//        Person *person = [Person new];
//        //此处autorelease是标记释放 并不是真正的释放,后面仍然可以正常使用对象,一直到autorelease花括号结束处,会调用dealloc方法
//        [person autorelease];
//        //不建议,过度释放
//        [person autorelease];

自动释放池创建及简单使用

NSAutoreleasePool *pool = [NSAutoreleasePool new];//@autoreleasepool{
//        
//        Person *per2 = [Person new];
//        [per2 retain];
//        
//        //使用属性的set方法赋值
//        per2.name = @"大桶";
//        
//        //使用KVC方法赋值
//        [per2 setValue:@20  forKey:@"age"];
//        
//        NSLog(@"%@",per2.name);
//        NSLog(@"%@",[per2 valueForKey:@"age"]);
//        
//        
//        
//        
//        
//        [per2 release];
//        
//        [per2 release];
//        
//        [pool release];//}
        
        //自动释放池嵌套使用
//        @autoreleasepool {
//            Person *per4 = [[Person new] autorelease];
//        }


ARC内存管理机制

(一)ARC的判断准则:
只要没有强指针指向对象,对象就会被释放。
(二)指针分类:
(1)强指针:默认的情况下,所有的指针都是强指针,关键字strong
(2)弱指针:__weak关键字修饰的指针
声明一个弱指针如下:
__weak Person *p;
ARC中,只要弱指针指向的对象不在了,就直接把弱指针做清空操作。
weak Person *p=[[Person alloc] init];//不合理,对象一创建出来就被释放掉,对象释放掉后,ARC把指针自动清零
ARC中在property处不再使用retain,而是使用strong,在dealloc中不需要再[super dealloc]。
@property(nonatomic,strong)Dog *dog;// 意味着生成的成员变量dog是一个强指针,相当于以前的retain。
如果换成是弱指针,则换成weak,不需要加

上一篇下一篇

猜你喜欢

热点阅读