OC之ARC环境中的循环strong问题

简介:

main.m文件:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
#import <Foundation/Foundation.h>
#import "Person.h"
#import "Dog.h"
 
int main()
{
     Person *p = [[Person alloc] init];
    Dog *d = [[Dog alloc] init];
    p.dog = d;
    d.person = p;
 
    return 0;
}

Dog.m文件: 

?
1
2
3
4
5
6
7
8
#import "Dog.h"
 
@implementation Dog
- ( void )dealloc
{
    NSLog(@ "Dog--dealloc" );
}
@end

 Person.m文件: 

?
1
2
3
4
5
6
7
8
9
10
#import "Person.h"
 
@implementation Person
 
- ( void )dealloc
{
    NSLog(@ "Person--dealloc" );
}
 
@end
Dog.h文件:

?
1
2
3
4
5
6
7
8
9
#import <Foundation/Foundation.h>
 
@ class Person;
 
@interface Dog : NSObject
 
@property (nonatomic,strong) Person *person;
 
@end

 Person.h文件:

?
1
2
3
4
5
6
7
8
9
#import <Foundation/Foundation.h>
 
@ class Dog;
 
@interface Person : NSObject
 
@property (nonatomic, strong) Dog *dog;
 
@end

对于上述main.m文件中红色部分“人养一条狗,狗有一个主人”,仔根据两个.h文件中部分,编译运行时会出现“人strong狗,狗strong人”的情况,导致p和d占用的内存无法被回收,即上图黄色部分不打印。解决办法为:

一端用strong,另一端用weak

比如可以将Dog.h文件中strong改成weak,就可以解决循环strong 问题。

目录
相关文章
23avalon - 指令ms-visible(可见性绑定)
23avalon - 指令ms-visible(可见性绑定)
50 0
|
iOS开发
iOS block修饰符用copy还是strong
iOS block修饰符用copy还是strong
177 0
iOS-底层原理 10:strong&copy&weak底层分析 以及 方法签名和attribute简写含义
iOS-底层原理 10:strong&copy&weak底层分析 以及 方法签名和attribute简写含义
175 0
iOS-底层原理 10:strong&copy&weak底层分析 以及 方法签名和attribute简写含义
|
Android开发
【Android 逆向】x86 汇编 ( align | db | dw | dd | nop | 伪指令 )
【Android 逆向】x86 汇编 ( align | db | dw | dd | nop | 伪指令 )
242 0
|
存储 缓存

热门文章

最新文章