对Block用copy修饰的理解

  • MRC模式下,block默认是存档在栈中的,随时可能被系统回收,进行copy操作,就可以将block放在堆中,形成互相指引的效果,当然此时需要注意block闭环引起的内存泄露问题。如果使用retain操作,只会使其引用计数+1,block内存还是在栈中,并没有转移到堆上。
  • ARC模式下,使用copy或者strong,其效果是一样的,编译器自动对block进行了copy操作。如果用copy修饰block,也是提醒我们:编译器自动对block进行了copy操作,不用copy修饰也可以,如果使用者在使用之前对其自行copy的话,就显得多余而低效。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`direct` 修饰的变量可以使用 RAC,但需要注意一些细节。 由于 `direct` 是一个实例变量,而不是 `@property`,因此不能使用 `RAC` 提供的默认的 `@synthesize` 指令来自动生成访问器方法。如果想在 `RAC` 中使用 `direct` 变量,需要手动实现访问器方法。 下面是一个示例代码: ```objective-c @interface MyClass : NSObject @property (nonatomic, copy) NSString *indirectProperty; @end @implementation MyClass { NSString *_directProperty; } - (NSString *)directProperty { return _directProperty; } - (void)setDirectProperty:(NSString *)directProperty { _directProperty = [directProperty copy]; } @end ``` 这样,在使用 `RAC` 时,就可以通过访问器方法来访问 `direct` 变量了,例如: ```objective-c MyClass *obj = [[MyClass alloc] init]; [obj rac_observeKeyPath:@"directProperty" options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld observer:nil block:^(id value, NSDictionary *change, BOOL causedByDealloc, BOOL affectedOnlyLastComponent) { NSLog(@"directProperty changed: %@", value); }]; obj.directProperty = @"new value"; ``` 需要注意的是,当使用 `RAC` 观察 `direct` 变量时,不能直接使用 `RACObserve` 宏,而需要使用 `rac_observeKeyPath:options:observer:block:` 方法来观察变量。这是因为 `RACObserve` 宏只能用来观察 `@property` 修饰的变量,不能用来观察实例变量。另外,需要手动实现访问器方法,才能让 `RAC` 正常工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值