Objective-C MRC多个对象相互引用的内存管理

在MRC环境下,假定CTRoom对象是CTPerson的一个成员变量,那么修改CTRoom对象时应注意,代码如下:

- (void) setRoom:(CTRoom *) room
{   //需判断新旧值是否相等,一旦相等则[_room release]等价于[room release],那么[room retain]将抛出异常。
    if(_room != room){
        [_room release];  //释放旧值
        _room = [room retain];  //retain新值
    }
}

- (void) dealloc

{

//    [_room release];

//    _room = nil;

self.room = nil; //同时,这一句代码等效前面两句

[super dealloc];]

}

 
    CTPerson *person = [[CTPerson alloc] init];
    CTRoom *r = [[CTRoom alloc] init];
    [person setRoom:r];
    [r release];
    person.room = r;
    [person release];
    
时间: 2024-11-03 22:59:10

Objective-C MRC多个对象相互引用的内存管理的相关文章

初探swift语言的学习笔记六(ARC-自动引用计数,内存管理)

Swift使用自动引用计数(ARC)来管理应用程序的内存使用.这表示内存管理已经是Swift的一部分,在大多数情况下,你并不需要考虑内存的管理.当实例并不再被需要时,ARC会自动释放这些实例所使用的内存. 另外需要注意的: 引用计数仅仅作用于类实例上.结构和枚举是值类型,而非引用类型,所以不能被引用存储和传递. swift的ARC工作过程 每当创建一个类的实例,ARC分配一个内存块来存储这个实例的信息,包含了类型信息和实例的属性值信息. 另外当实例不再被使用时,ARC会释放实例所占用的内存,这些

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

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

iOS 相互引用引起内存泄露问题说明

release动作只会对自身计数减一,而不会对属性发出release消息,只有该对象的引用计数为0,系统才会对该对象的所有属性发出release消息 类A的属性有类B,类B的属性有类A,而且两者都是强引用retain 实例化后[A retainCount]是2    [B retainCount]是2 [A release] 后  [A retainCount]是1    [B retainCount]是2 [B release]后   [A retainCount]是1    [B retai

初步swift语言学习笔记6(ARC-自己主动引用计数,内存管理)

笔者:fengsh998 原文地址:http://blog.csdn.net/fengsh998/article/details/31824179 转载请注明出处 假设认为文章对你有所帮助.请通过留言或关注微信公众帐号fengsh998来支持我,谢谢. Swift使用自己主动引用计数(ARC)来管理应用程序的内存使用.这表示内存管理已经是Swift的一部分,在大多数情况下,你并不须要考虑内存的管理. 当实例并不再被须要时.ARC会自己主动释放这些实例所使用的内存. 另外须要注意的: 引用计数仅仅

iOS中引用计数内存管理机制分析

在 iOS 中引用计数是内存的管理方式,尽管在 iOS5 版本号中.已经支持了自己主动引用计数管理模式.但理解它的执行方式有助于我们了解程序的执行原理.有助于 debug 程序. 操作系统的内存管理分成堆和栈. 在堆中分配的内存,都试用引用计数模式:在栈中则不是. NSString 定义的对象是保存在栈中,所以它没有引用计算.看一些书上说它的引用计算会是 fffffffff 最大整数.測试的结果显示它是- 1. 对该对象进行 retain 操作.不好改变它的 retainCount 值. Mut

Java对象和它的内存管理

java中的内存管理分为两个方面: 内存分配:指创建java对象时JVM为该对象在堆空间中所分配的内存空间. 内存回收:指java 对象失去引用,变成垃圾时,JVM的垃圾回收机制自动清理该对象,并回收该对象所占用的内存. 虽然JVM 内置了垃圾回收机制,但仍可能导致内存泄露.资源泄露等,所以我们不能肆无忌惮的创建对象.此外,垃圾回收机制是由一个后台线程完成,也是很消耗性能的. 1.实例变量和类变量 java程序中的变量,大体可以分为 成员变量 和 局部变量 .其中局部变量可分为如下三类: 形参

iOS中引用计数内存管理机制分析总结(NSString引用计数为-1的情况)

在 iOS 中引用计数是内存的管理方式,虽然在 iOS5 版本中,已经支持了自动引用计数管理模式,但理解它的运行方式有助于我们了解程序的运行原理,有助于 debug 程序.   操作系统的内存管理分成堆和栈. 在堆中分配的内存,都适用引用计数模式:在栈中则不是. NSString 定义的对象是保存在栈中,所以它没有引用计数,不是通过引用计数对内存进行管理的.之前我在一篇博客上看,说常量的引用计数会是一个很大的整数,测试的结果显示它是-1. 对该对象进行 retain 操作,不好改变它的 reta

spring中的相互引用问题

IOC指spring来创建对象实例,而不是Java代码中来做. DI指spring根据对象的关系来注入相互之间的关系. DI会引起相互引用的问题,即两个对象相互引用.相互依赖,类似于死锁的问题导致系统无法完成实例化. 报错如下: Caused by: org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'myBoss2': Requested bean 

垃圾回收与对象的引用

垃圾回收 当程序创建对象.数组等引用类型实体时,系统就会在对内存中为之分配一块内存区,对象就保存在这块内存区中,当这块内存不再被任何引用变量引用时,这块内存就变成垃圾,等待垃圾回收机制进行回收. 垃圾回收机制具有如下特点: 垃圾回收机制只负责回收堆内存中的对象,不会回收任何物理资源. 程序无法精确控制垃圾回收的运行,垃圾回收会在合适的时候进行.当对象永久性地失去引用后,系统就会在合适的时候回收它所占的内存. 在垃圾回收机制回收任何对象之前,总会调用它的finalize()方法,可以重写该方法,让