美文网首页
内存管理思想

内存管理思想

作者: 2d2383806a31 | 来源:发表于2017-10-25 10:08 被阅读0次

一、内存管理的思考方式

内存管理的思想包括以下四点:

1、自己生成的对象,自己所持有

2、非自己生成的对象,自己也能持有

3、不再需要自己持有的对象时,要释放

4、非自己持有的对象 不能释放

自己生成的对象自己持有

 alloc 、new、copy、mutableCopy

这些名称开头的方法名意味着自己生成的对象只有自己持有;上文中出现了一系列的自己这个词,可以将自己理解为“对象的使用环境”,也可以理解为编程人员“自身”。下面写出了自己生成并持有对象的源代码。我们在这里使用alloc方法:

//自己生成对象并持有对象

id obj =[ [NSObject alloc] init];

//自己持有对象

使用alloc类方法就能自己生成并持有对象。指向生成并持有对象的指针被赋给变量obj,另外,使用new类方法也可以生成并持有对象。和alloc时完全一致的

//自己生成对象并持有对象

id obj =[NSObject new];

//自己持有对象

copy方法利用基于NSCopying方法约定,由各类实现的copyWithZone:方法生成并持有对象副本。与copy方法类似,mutableCopy方法利用基于NSMutableCopying方法约定,由各类实现的mutableCopyWithZone:方法生成并持有对象的副本。 用这些方法生成的对象,虽然是对象的副本,但是和alloc、new一样,在”自己生成并持有对象“这点上没有发生改变;

非自己生成的对象,自己也能持有

用alloc/new/copy/mutableCopy以外的方法取得的对象,因为非自己生成并持有,所以自己不是该对象的持有者。看以下源代码:

//取得非自己生成并持有的对象

id obj = [NSMutableArray array];

//取得对象的存在,但自己不持有对象

上述代码中,NSmutableArray类对象被赋值给变量obj,但变量obj自己并不持有该对象。使用retain方法可以持有对象

//取得非自己生成并持有的对象

id obj = [NSMutableArray array];

//取得对象的存在,但自己不持有对象

[obj retain];

//自己持有对象

通过retain方法,非自己生成的对象跟用alloc/new/copy/mutableCopy方法生成并持有的对象一样,成为了自己所持有的。

不再需要自己持有的对象时 ,要释放

自己持有的对象,一旦不在需要,持有者有义务释放该对象。释放使用release方法。

//自己生成并持有对象

id obj = [[NSObject alloc] init];

//自己持有对象

[obj release];

//释放对象,指向 对象的指针  仍然被保留在变量obj中,貌似可以访问。但是 对象 一经释放不可访问

如此,用alloc方法由自己生成并持有的对象就通过release方法释放了。自己生成而非自己所持有的对象,若用retain方法变为自己持有,也同样可以用release方法释放。

//取得非自己生成并持有的对象

id obj = [NSMutableArray array];

//取得对象存在,但自己不持有对象

[obj retain];

//自己持有对象

[obj release];

//释放对象,对象  不可再被访问

那么如果要用某个方法生成对象,并将其返还给该方法的调用方,那么它应该怎么操作呢,如下:

- ( id ) allocObject

{

        //自己生成并持有对象

       id obj = [[NSObject alloc ] init ];

        //自己持有对象

      return obj;

}

如上,原封不动返回用alloc方法生成并持有的对象,就能让调用方也持有该对象。

//取得非自己生成并持有的对象

id obj1 = [obj0 allocObject];

//自己持有对象

那么,如何像调用[NSMutableArray array] 方法使取得的对象存在,但自己不持有对象,又是如何实现的呢?如下:

- ( id ) allocObject

{

        //自己生成并持有对象

        id obj = [[NSObject alloc ] init ];

       [obj autorelease];

       //取得对象的存在,但是自己不持有对象。

        return obj;

}

上述代码中,我使用了autorelease方法。用该方法,可以使取得的对象存在,但自己不持有对象。以后有时间我会详细介绍autorelease。

id obj1 = [obj0 object];

//取得的对象存在,但自己不持有对象。

当然也可以像前文中的NSMutableArray一样,通过retain 方法,将调用autorelease方法取得的对象变为自己持有。

无法释放非自己持有的对象

对于由alloc/new/copy/mutableCopy 方法生成并持有的对象,或是retain方法持有的对象,由于持有者是自己,所以在不需要该对象的时候,需要将其释放。而由此以外所得到的对象绝对不能释放。如果在应用程序中释放了非自己所持有的对象就会造成崩溃。例如自己生成的并持有对象后,在释放完不再需要的对象之后再次释放。

//自己生成并持有对象

id obj = [[NSObject alloc] init];

//自己持有对象

[objc release];

//对象已被释放

[obj release];

//释放之后再次释放已非自己持有的对象,应用程序崩溃

//崩溃情况:再度废弃一经废弃了的对象时崩溃   、 访问一经废弃的对象时崩溃;

或者在“取得的对象存在,但自己不持有对象”时释放

id obj1 = [obj0 object];

[obj1 release];

//释放了非自己持有的对象,这肯定会导致应用程序崩溃

如这些例子所示,释放非自己持有的对象会造成程序崩溃。因此绝对不要去释放非自己持有的对象。

相关文章

  • 内存管理思想

    一、内存管理的思考方式 内存管理的思想包括以下四点: 1、自己生成的对象,自己所持有 2、非自己生成的对象,自己也...

  • 内存管理的思想

    1.ARC编译器自动生成内存管理的代码 几十M的程序,闪退想象,内存超出的时候 堆(对象)(手动释放,oc给对象发...

  • 《Objective-C高级编程:iOS与OS X多线程和内存管

    听说这本书很好,所以在项目不怎么忙的时候就读了读。总结了点笔记。 手动内存管理MRC 内存管理的思想思想一:自己生...

  • OC的内存管理

    1、OC的内存管理 OC是通过引用计数进行内存管理的,其核心思想遵循“谁创建谁释放;谁引用谁管理”。 OC的内存管...

  • 8.池化内存分配

    netty内存管理思想 PooledByteBufAllocate PoolChunkChunk初始化PoolCh...

  • iOS内存管理详解

    目录 block内存管理 autorelease内存管理 weak对象内存管理 NSString内存管理 new、...

  • 第10章 内存管理和文件操作

    1 内存管理 1.1 内存管理基础 标准内存管理函数堆管理函数虚拟内存管理函数内存映射文件函数 GlobalMem...

  • 操作系统之内存管理

    内存管理 包括内存管理和虚拟内存管理 内存管理包括内存管理概念、交换与覆盖、连续分配管理方式和非连续分配管理方式(...

  • JavaScript —— 内存管理及垃圾回收

    目录 JavaScript内存管理内存为什么需要管理?内存管理概念JavaScript中的内存管理JavaScri...

  • OC - OC的内存管理机制

    导读 一、为什么要进行内存管理 二、内存管理机制 三、内存管理原则 四、MRC手动内存管理 五、ARC自动内存管理...

网友评论

      本文标题:内存管理思想

      本文链接:https://www.haomeiwen.com/subject/rcafpxtx.html