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 retainCount]是1

出现A,B无法释放导致内存泄露

如果A的属性B使用assign修饰

实例化后[A retainCount]是2    [B retainCount]是1

[A release] 后  [A retainCount]是1    [B retainCount]是1

[B release]后   [A retainCount]是1    [B retainCount]是0     由于B的retianCount是0所以被系统回收,系统会对B的所有属性发出一个release消息,

这时候A被release,引用计数为0,不会内存泄露

时间: 2024-12-15 01:32:26

iOS 相互引用引起内存泄露问题说明的相关文章

在iOS上自动检测内存泄露

手机设备的内存是一个共享资源.应用程序可能会不当的耗尽内存.崩溃,或者遭遇大幅度的性能降低. Facebook iOS客户端有很多功能,并且它们共享同一块内存空间.如果任何特定的功能消耗过多的内存,就会影响到整个应用程序.这是可能发生的,比如,这个功能导致了内存泄露. 当我们分配了一块内存,并设置了对象之后,如果在使用完了之后忘记释放,这就会发生内存泄露.这意味着系统是无法回收内存并交予他人使用,这也最终意味着我们的内存将会逐渐耗尽. 在Facebook,我们有很多工程师在代码库的不同部分上工作

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

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

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

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

避免长期持有了一个Context的引用造成内存泄露

Android上 ,Context可以用于很多操作,但是大部分时候是用来加载以及使用资源.这就是为什么所有的widgets在他们的构造函数中接受一个Context参数.在一般的android应用中,你通常有两种Context:分别是Activity和Application.通常的,当我们的类和方法需要使用到context时,我们传递的是Activity这个context. [java] @Override protected void onCreate(Bundle state) { super

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新值 } } - (

.NET中常见的内存泄露问题——GC、委托事件和弱引用

一.什么是内存泄露(memory leak)? 内存泄露不是指内存坏了,也不是指内存没插稳漏出来了,简单来说,内存泄露就是在你期待的时间内你程序所占用的内存没有按照你想象中的那样被释放. 因此什么是你期待的时间呢?明白这点很重要.如果一个对象占用内存的时间和包含这个对象的程序一样长,但是你并不期望是这样.那么就可以认为是内存泄露了.用具体例子来说明如下: class Button { public void OnClick(object sender, EventArgs e) { ... }

使用gc、objgraph干掉python内存泄露与循环引用!

Python使用引用计数和垃圾回收来做内存管理,前面也写过一遍文章<Python内存优化>,介绍了在python中,如何profile内存使用情况,并做出相应的优化.本文介绍两个更致命的问题:内存泄露与循环引用.内存泄露是让所有程序员都闻风丧胆的问题,轻则导致程序运行速度减慢,重则导致程序崩溃:而循环引用是使用了引用计数的数据结构.编程语言都需要解决的问题.本文揭晓这两个问题在python语言中是如何存在的,然后试图利用gc模块和objgraph来解决这两个问题. 注意:本文的目标是Cpyth

iOS性能优化之内存管理:Analyze、Leaks、Allocations的使用和案例代码 -[转载]

最近研究代码质量检测问题,在网上找的相关资料咱是如下: 一. 一些相关概念 很多人应该比较了解这块内容了...可以权当复习复习... 1.内存空间的划分: 我们知道,一个进程占用的内存空间,包含5种不同的数据区:(1)BSS段:通常是存放未初始化的全局变量:(2)数据段:通常是存放已初始化的全局变量.(3)代码段:通常是存放程序执行代码.(4)堆:通常是用于存放进程运行中被动态分配的内存段,OC对象(所有继承自NSObject的对象)就存放在堆里.(5)栈:由编译器自动分配释放,存放函数的参数值

Android 开发避免内存泄露,无法回收

避免对Activity 或者context 的引用导致内存泄露. 1. 不要让生命周期比引用的Acitivity或者Context对象长: 2. 生命周期长的可以使用Application context: 3. 内部类,尽量使用静态类,避免内部类对外部对象引用导致的生命周期变化