iOS中的内存管理(下)

首先来看一个参数:@property(详见:http://my.oschina.net/aofe/blog/265789)

    @property在内存管理中的作用:

    1、可以控制set方法的内存管理;

    1> retain:release旧值,retain1新值(用于OC对象);

    2> assign:直接赋值,不做任何内存管理(默认,用于非OC对象类型);

    3> copy:release旧值,retain新值(一般用于NSString *)。

    2、控制需不需要生成set方法;

    1> readwrite:同时生成set和get方法(默认);

    2> readonly:只生成get方法;

    3、多线程管理;

    1> atomic:性能低(默认);

    2> nonatomic:性能高

    关于内存管理中的循环retain问题的解决:

    循环retain场景:比如A对象retain了B对象,B对象retain了A对象;

    循环retain的弊端:这样会导致A对象和B对象永远无法销毁(因为互相引用);

    循环retain的解决方法:两端相互引用时应该一端用retain,一端用assign。

    以上基本就是MRC机制下的内存管理方法,下面介绍ARC机制下的内存管理方法。首先,要了解autorelease。

    autorelease方法的基本使用:

    1> 给对象发送一条autorelease消息,会将对象放到一个自动释放池(autoreleasepool)中;

    2> 当自动释放池被销毁时,会对池子里面的所有对象做一次release操作;

    3> 会返回对象本身;

    4> 调用完autorelease方法后,对象的计数器不变。

    autorelease的好处:

    1> 不用在关心对象释放的时间;

    2> 不用在关心什么时候调用release。

    autorelease的使用注意:

    1> 占用内存较大的对象不要随便使用autorelease;

    2> 占用内存较小的对象使用autorelease,没有太大影响。

    自动释放池(autoreleasepool):

    在iOS程序运行过程中,会创建无数个池子,这些池子都是以栈结构存在(先进后出);当一个对象调用autorelease方法时,会将这个对象放到栈顶得释放池。

    自动释放池的创建方式:

    1> iOS 5.0前:

NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];  
[pool release];

    2> iOS 5.0后: 

@autoreleasepool { 
  }

    autorelease的常见错误:

    1、alloc之后调用了autorelease,又调用了release;

Person *p = [[[Person alloc] init] autorelease];
[p release];

    2、连续调用多次autorelease。

Person *p = [[[[Person alloc] init] autorelease] autorelease];

    autorelease和release使用对比

/* 使用release */ 
Book *book = [[Book alloc] init];
[book release]; 

/* 使用autorelease */  
Book *book = [[[Book alloc] init] autorelease];
// 不要再调用[book release];

    autorelease的使用场合:

    一般可以为类添加一个快捷创建对象的方法:

+ (instancetype)book {   
     return [[[self alloc] init] autorelease];
 }

    外界调用[Book book]就可以获得和使用新建的Book对象,根本不用考虑在什么时候释放Book对象。

    一般来说,除了alloc、new或copy之外的方法创建的对象都被声明了autorelease。

    比如下面的对象都已经是autorelease的,不需要再release。

NSNumber *number = [NSNumber numberWithInt:250];
NSString *name = [NSString stringWithFormat:@"jack"];
NSString *stu = @"rose";

    ARC是自iOS 5.0之后增加的新特性,是iOS程序员的福音。

    ARC的全称是:Automatic Reference Counting(自动引用计数)

    MRC的全称是:Manual Reference Counting(手动引用计数)

    ARC的实现细节:

        编译器会自动在适当地地方插入适当的retain、release、autorelease等语句;也就是说,编译器会自动生成内存管理的代码,不用程序员手动编写。

    ARC注意点:

    1、ARC是编译器特性,而不是运行时特性;

    2、ARC不是其他语言中的垃圾回收,有着本质的区别。

    ARC的优点:

    1、完全消除了手动管理内存的繁琐,让程序员更加专注于app业务;

    2、基本上能够避免内存泄漏;

    3、有时还能更加快速,因为编译器还可以执行某些优化。

    ARC的判断原则:只要还有一个强指针变量指向对象,对象就会保持在内存中。

    强指针:默认所有的指针变量都是强指针;被_strong修饰的指针。

    弱指针:被_weak修饰的指针。

    ARC使用细节:

    不能调用release、retain、autorelease、retainCount

    可以重写dealloc,但是不能调用[super dealloc];

    ARC中的@property:

    strong:用于OC对象,相当于MRC中的retain。

    weak:用于OC对象,相当于MRC中得assign。

    assign:用于基本数据类型,跟MRC中得assign一样。

    copy: 一般用于NSString,跟MRC中得copy一样。

    


转载于:https://my.oschina.net/aofe/blog/267337

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值