内存管理池

1、如果想要调用release,必须开启ARC

2、[实例对象 autorelease] 这个方法就是吧实例对象放到自动释放池中。(内存报警或者程序结束时自动释放)

3、@autoreleasepool  {} 自动释放池。

自动内存管理/ARC(Automatic Reference Counting)

1、自动内存管理

编译器自动的添加完成了内存管理的引用计数代码。(苹果公司支持用的)

2、ARC使用原则

3、ARC/MRC混编

ARC原则

1、代码中不能使用retain,release,autorelease

2、不重载dealloc(可以重写覆盖,不能调用)(如果是释放对象内存以外的处理,是可以重载该函数的,但是不能调用)

3、不能使用NSAllocateObject,NSDeallocateObject

4、不能再C结构体中使用对象指针

5、id与void*间的如果cast时需要用特定的方法

6、不能使用NSAutoReleasePool、而需要@autoreleasepool块

7、不能使用”new“开始的属性名称(如果使用会有下面的编译错误)

ARC和MRC(手动内存管理)混编

MRC口诀

1、谁创建,谁释放,如果你通过alloc new copy来创建一个对象,那么你必须调用release或者这

autorrelease。换句话说,,不是你创建的,你就不用去释放。

例如你在函数中alloc生成了一个对象,且这个对象只再这个函数中被使用,那么你必须在这个函数

中调用release或者autorelease,如果你在一个class的某个方法中调用release,如果调用了autorelease

那么再dealloc方法中声明都不需要做

2、除了alloc、new、copy之外的方法创建的对象都被声明了autorelease。

3、谁retain,谁release。只要你调用了retain,无论这个对象是如何生成的,你都要调用release

时间: 2024-10-14 04:51:49

内存管理池的相关文章

PoolManager 内存管理池,动态加载

public class MyPoolTest : MonoBehaviour { private SpawnPool spawnPool; private PrefabPool refabPool; void init(){ spawnPool  = PoolManager.Pools.Create("aabb"); spawnPool  = PoolManager.Pools.Create("aabb"); spawnPool.group.parent = th

Cocos2d之“引用计数”内存管理机制实现解析

一.引言 本文主要分析cocos2d游戏开发引擎的引用计数内存管理技术的实现原理.建议读者在阅读本文之前阅读笔者之前一篇介绍如何使用cocos2d内存管理技术的文章--<Cocos2d之Ref类与内存管理使用详解>. 二.相关概念 引用计数 引用计数是计算机编程语言的一种内存管理技术,是指将资源(对象.内存或者磁盘空间等)的被引用计数保存起来,当引用计数变为零时就将资源释放的过程.使用引用计数技术可以实现自动内存管理的目的. 当实例化一个类时,对象的引用计数为1,在其他对象需要持有这个对象时,

Cocos2d-x内存管理

Cocos2d-x内存管理浅解 1.首先我们知道内存管理分为c++自身管理机制以及Cocos2d-x内存管理机制.在c++中,内存分为堆区.栈区.静态存储区(全局存储区).常量存储区.自由存储区. 主要先说一下堆区和栈区.堆区主要由new和malloc分配,new与delete,malloc与free成对出现,保证内存的分配与回收.堆内存分配地址是逐渐增大的,这一点与栈区相反,我们都知道栈是先进后出,所以栈的存储方向是内存地址逐渐减小的.栈中的内存也是系统自动回收的,这个我们不需要考虑自己管理内

cocos2d内存管理

设想如下场景, 这是一个典型的内存合理分配的场景: 在一帧内, 有若干个函数, 每个函数都会创建一系列的精灵, 每个精灵都不同, 都会占用一定的内存, 精灵的总数可能会有1000个, 而一个函数只会创建10个精灵这样, 创建的精灵只会在这个函数中使用, 大致代码如下: for(int i = 0; i < 10; i++) { Sprite* s = Sprite::create(); //-- doSomething -- } 这样做会造成内存泄露吗? 答案是当然不会, 但是这样会造成一帧内的

Objective-C(十六、内存管理,自动释放池,ARC,强指针,弱指针,方法族)——iOS开发基础

结合之前的学习笔记以及参考<Objective-C编程全解(第三版)>,对Objective-C知识点进行梳理总结.知识点一直在变,只是作为参考,以苹果官方文档为准~ 十六.内存管理相关知识(二) 1.autorelease,自动释放机制 - (instancetype)autorelease; (1)自动释放池的创建 iOS5.0之前 NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; //进行一系列操作 //此处不可以使用

手动内存管理和自动释放池

手动内存管理 在进行内存管理的时候要注意内存管理的准则:谁开辟内存,谁释放内存(谁污染的谁治理) .开辟内存之后,对象的引用计数为1,只有继承自NSObject的对象才有内促管理的概念, 当对象引用计数为0的时候对象的内存会被清理. 下列关键字会开辟内存,对象引用计数器+1 alloc new copy mutableCopy 下列是内存管理的相关方法. retain :保留对象,对象的引用计数器+1. release : 释放对象,对象引用计数器-1. retainCount : 获取对象当前

Objective-C(8)内存管理之自动释放池

自动释放池 是一种半自动的内存管理方式 autorealease方法: - (instancetype)autorelease 此方法将对象放到自动释放池中,当自动释放池销毁时,池中的所有对象都会随之销毁. 常见的使用方式: Person *p = [[[Perosn alloc] init] autorelease]; 使用@autoreleasepool关键字来使用自动释放池 其后的{-}相当于自动释放池的生存期 ,如: @autoreleasepool {      Person *p =

objective-C 的内存管理之-自动释放池(autorelease pool)

如果一个对象的生命周期显而易见,很容易就知道什么时候该new一个对象,什么时候不再需要使用,这种情况下,直接用手动的retain和release来判定其生死足矣.但是有些时候,想知道某个对象在什么时候不再使用并不那么容易.如果下面的代码,看上去非常简单: Sample.h类接口部分 #import @interface Sample : NSObject { } -(NSString*) toString; @end Sample.m 类实现部分 #import "Sample.h"

黑马程序员----内存管理之四——《autorelease自动释放池》

内存管理之四——autorelease自动释放池 1.autorelease的基本使用 此对象方法会将对象放到一个自动释放池内: 当自动释放池被销毁时,就会对池子内的所有对象做一次release操作: 此方法会返回对象本身: 调用完此方法后,对象计数器的值不变,只有到自动释放池被销毁时才会对对象做一次release操作: 2.autorelease的好处 不用在关心对象被销毁的时间: 不用关心什么时候调用release操作: 3.autorelease的使用注意 占用内存较大的对象不要随便使用a