OC--内存管理

------------内存管理---------------

内存管理分类:ARC(自动内存管理) 和MRC (手动内存管理)

ARC:内存管理的事情有系统来做

MRC: 内存管理的事情由程序员来做

要想手动管理内存,先要将程序变成手动内存管理状态

retain 使引用计数+1

release 使引用计数 -1

alloc/copy/new 都会使引用计数 +1  ,但是只用于创建对象

retainCount :记录引用计数器的值

注意:内存的法则:引用计数有+1就要有-1,保持平衡。

  野指针:指向僵尸对象的指针

  空指针:保存的时nil

当一个对象的retainCount值为0的时候,即被释放的时候,系统会调用dealloc方法

  @implementation Person

注意:系统自动调用的方法 ,通过这个方法判断对象是否被释放了

  -(void)dealloc{

//只要调用dealloc方法就必须写这行代码,而且必须写在方法的最后面

      [super dealloc];}

  Person *person = [[Person alloc]init];   开始创建,retainCount==1

  [person retain];    //retainCount +1

  [person release];  //retainCount - 1

注意:给对象发送release消息,并不代表释放对象,只是使retainCount-1.

   释放对象是当对象的retainCount==0的时候

--------一个对象被多个对象使用

  重写dealloc方法

  此类中使用另一类作为属性   @property (nonatomic,retain)Room *room;

  -(void)dealloc{

  //当成员变量所在的对象被释放的时候,对象里面的内容也应该一起被释放

      [_room release];

      [super dealloc];}

-------------copy,mutablecopy----------

注意:首先要遵守copy,mutablecopy相关的协议(NSCoping,NSMutbaleCoping)。

NSstring等已经遵守了这个协议了,所以可以直接使用,但是自定义的类,就要先去遵守并实现相关协议。

  NSString *string1 = @"good for you";

//将原字符串,拷贝了一份,放到了一个新开辟的空间。这个新的字符串是可变的   -- 通过mutableCopy得到的是可变字符串

NSMutableString *mutString1  = [string1 mutableCopy];

[mutString1 setString:@"OK"];

NSString *newString = [mutString1 copy];

---------自动释放池-----------

  自动释放池:一个程序可以有很多个自动释放池。自动释放池是可以嵌套的

在嵌套的自动释放池当中创建的对象会以当前的自动释放池为参考进行操作。

  

NSAutoreleasePool *pool = [[NSAutoreleasePool alloc]init];//旧版本

[pool release];

  @autoreleasepool{//新版本

  Person *person = [[Person alloc]init];

//当给一个对象发送autorelease消息的时候,系统会讲对象放入当前的自动昂释放池的一个数组当中

[person autorelease];

//[person release];

}//当当前的自动释放池结束的时候,他会给里面的每个对象发送release消息

//使用自动释放池原因:因为有的时候创建的对象不便于立即释放,所以给他么发送autorelease消息,到自动释放池结束的时候一起释放}

//注意:当没有使用alloc,copy,new,retain的时候,不能使用release,因为要保持retainCount的平衡。

//不要拿数组,字典的retaincount值做一些事情(判断对象的所有者个数)

//数组的addObject:方法在使用的时候,会给元素自动给的引用计数+1

时间: 2024-07-31 22:45:37

OC--内存管理的相关文章

OC内存管理

OC内存管理 一.基本原理 (一)为什么要进行内存管理. 由于移动设备的内存极其有限,所以每个APP所占的内存也是有限制的,当app所占用的内存较多时,系统就会发出内存警告,这时需要回收一些不需要再继续使用的内存空间,比如回收一些不再使用的对象和变量等. 管理范围:任何继承NSObject的对象,对其他的基本数据类型无效. 本质原因是因为对象和其他数据类型在系统中的存储空间不一样,其它局部变量主要存放于栈中,而对象存储于堆中,当代码块结束时这个代码块中涉及的所有局部变量会被回收,指向对象的指针也

OC内存管理-1

栈区:从高到低分配 堆区:从低到高 BSS段:没有初始化的 数据区: 代码段: OC内存管理方式: 1 MRC 手动内存管理 2 ARC 自动内存管理 nil是给对象赋空值 下个有道云笔记 内存管理 一.总结: 1.只有OC对象才需要内存管理,基本数据类型无效 2.OC对象存放在堆里面 3.非OC对象一般放在栈里面(栈内存会被系统自动回收) 二.引用计数器: 1.每个OC对象都有自己的引用计数器 2.它是一个整数(int) 3.表示有多少人正在使用这个对象 4.每个OC对象都有4个字节的存储空间

OC内存管理(一)

OC内存管理: 前言:为什么基本数据类型分配在栈区,而动态分配的内容在堆区. 因为基本数据类型的存放的数据在内存中得大小是固定的比如int类型的数据就是分配-2^31——2^31-1.而要分配不确定的数据在内存中得话,就动态分配到堆区. 一:基本原理 1>为什么要进行内存管理. 内存管理的范围是:继承自NSObjetc的类对象,对基本数据类型无效 我们知道手机的内存非常有限,而基本数据类型在编译时会静态分配内存在栈区,当代码块结束时,栈区的成员变量自动释放,当然指向对象的指针也会被释放.而对象是

OC内存管理2

这里是新的内容 OC内存管理2,布布扣,bubuko.com

黑马程序员-OC内存管理 @property的增强

涉及到内存管理,只读,多线程等很多功能时,setter和getter方法也就没那么简单了:当然@property依然强大,很好用: 1:内存管理相关参数: *:retain:  (如果是oc对象类型),生成的setter会自动release旧值,retain新值: *:assign:(适用于非oc对象)  这个是默认的值 *:copy:release旧值,copy新值: @property (retain) NSString *name; // 同类型的参数不能同时写 // @property

oc 内存管理小结(**输出才是最好的学习**)

引言 内存管理:清理(回收)不用的内存,以便内存能够再次利用. 这里就需要关注——怎样确定对象不再需要使用,并且其占用的内存可以被收回. 在Xcode4.2发布之前,oc内存管理全靠程序员自己,即手工管理内存计数. 在Xcode4.2版本之后,支持自动引用计数(Automatic Reference Counting,ARC),即摆脱手工管理,程序员从烦恼的内存管理问题中彻底解脱,oyeah~~ 但是,为了理解过去遗留的代码,还是需要了解手工管理内存的原理.并且,也可以帮助coder们更明智地决

OC内存管理相关整理

OC内存管理 一.基本原理 (一)为什么要进行内存管理.内存管理的目的是什么? 由于移动设备的内存极其有限,所以每个APP所占的内存也是有限制的,当app所占用的内存较多时,系统就会发出内存警告,这时需要回收一些不需要再继续使用的内存空间,比如回收一些不再使用的对象和变量等. 管理范围:任何继承NSObject的对象,对其他的基本数据类型无效 管理目的: 1.不要释放或者覆盖还在使用的内存,这会引起程序崩溃: 2.释放不再使用的内存,防止内存泄露.(ios程序的内存资源很是宝贵.) 本质原因是因

OC内存管理详解

前言 由于移动设备的内存有限,所以我们需要对内存进行严格的管理,以避免内存泄露造成资源浪费.在OC中,只有对象才属于内存管理范围,例如int.struce等基本数据类型不存在内存管理的概念.在iOS开发中,对内存的管理实际上就是对引用计数器的管理. OC内存管理的三种方式 自动垃圾收集(Automatic Garbage Collection): 手动引用计数器(Manual Reference Counting)和自动释放池: 自动引用计数器(Automatic Reference Count

OC 内存管理机制总结

OC 内存管理机制总结 一:OC内存管理机制目前分为两块,其一自动内存管理机制,其二手动内存管理机制: 1.首先我们从自动内存管理机制讲起: 1)什么是自动内存管理机制,自动内存管理机制就是程序中所创造的成员变量交由系统统一处理,不需要外部人员干预,有点像java中gc(垃圾回收机制). 2)之前是没有自动内存管理机制的,后期苹果想拓展自己的开发市场,吸引其他平台开发者入住ios开发阵营,其中收到内存管理是很发杂的一块,对于转入IOS开发者不利,因此苹果推出了自动内存管理机制. 2.接下来我们将

OC内存管理总结,清晰明了!

<span style="font-size:18px;">OC内存管理 一.基本原理 (一)为什么要进行内存管理. 由于移动设备的内存极其有限,所以每个APP所占的内存也是有限制的,当app所占用的内存较多时,系统就会发出内存警告,这时需要回收一些不需要再继续使用的内存空间,比如回收一些不再使用的对象和变量等. 管理范围:任何继承NSObject的对象,对其他的基本数据类型无效. 本质原因是因为对象和其他数据类型在系统中的存储空间不一样,其它局部变量主要存放于栈中,而对象