【Objective-C】内存释放总结

 

1. 通过分配或复制创建的对象保持计数1

2. 假设任何别的方法获取的对象保持计数1,而且在自动释放池中. 要想在当前执行范围外使用该对象,就必须保持它

3. 向集合添加对象时它就被保持,从集合移除对象时就被释放.释放集合对象会释放该集合中的所有对象

4. 确保有多少alloc,copy,mutableCopy或retain消息就有多少release或autorelease消息发送给该对象. 换句话说,确保你的代码平衡

5. 在访问方法设置属性,先保持,再释放 (ztime: 现在有@propperty , @synthesize 两个指令自动创建此代码)

6. 用@"..."结构创建的NSString对象是常量.发送release或retain并无效果

 

 

内存释放是iphone开发过程中比较重的地方,所以在开辟内存后,我们必须小心、谨慎、并且及时的释放掉。

内存的释放,可以调用Dealloc函数,该函数可以释放,该类对象所占用的内存空间,为iphone节省宝贵的内存资源。

那么Dealloc函数是什么时候释放的哪?

以前网络上说是当 对象的引用计数 为0的时候,就可以调用iphone的垃圾回收机制,然后释放该资源,

但是一直没有真正的测试过,今天在编写游戏代码的过程看到了测试结果,确实是这个样子的。

测试代码如下:

我们先创建一个类:test_1,修改他的Dealloc函数

- (void)dealloc

{

  NSLog(@"this is test_1 view did dealloc !");//输出内容,表示调用该函数,并释放资源

[super dealloc];

}

我们在另一个地方创建他

test_1 *m_text;

if (m_text==nil)

{

  m_text = [[test_1 alloc] initWithNibName:nil bundle:nil];

}

int a = [m_text retainCount];//a = 1

[m_text retain];

int b = [m_text retainCount];//b = 2

[m_text release];

int c = [m_text retainCount];//c = 1

[m_text release];

int d= [m_text retainCount];//d = 1

m_text = nil;

int e= [m_text retainCount];//e = 0

 

经过测试发现,其实int d= [m_text retainCount];//d = 1该行代码中 d的理论之应该=0,表示该对象已经为空,

其所占用的内存资源已经得到释放, 也就是执行到改行代码后,调用了函数

- (void)dealloc

{

  NSLog(@"this is test_1 view did dealloc !");//输出内容,表示调用该函数,并释放资源

[super dealloc];

}

输出:

2011-10-25 16:05:13.333 Untitled[6358:207] test view did dealloc !

表示,对象m_text所占据的内存空间已经完全得到释放。

通过测试我们也发现,当一个对象的RetainCount函数=0的时候,系统会马上调用Dealloc函数释放该资源。


要想完全释放一个对象,的参考代码:

[m_text release];

m_text = nil;


你可能感兴趣的:(Objective-C,内存,iPhone,alloc,iphone内存)