Mrc+arc set方法

iOS arc和mrc下重写set方法

ARC下
@property (nonatomic, weak/assign) id delegate;
相当于
- (void)setDelegate:(id)delegate
{
if (_delegate != delegate) {
_delegate = delegate;
}
}

getter

-(NSString *)dic{
//将实例变量的引用计数加1后,添加自动减1
//作用,保证调用getter方法取值时可以取到值的同时在完全不需要使用后释放
return [[_brand retain] autorelease];
}
重写dealloc

//MRC下 手动释放内存 可重写dealloc但不要调用dealloc 会崩溃
-(void)dealloc{
[_string release];
//必须最后调用super dealloc
[super dealloc];
}

ARC即自动引用计数(Automatic Reference Counting),是iOS开发中编译器自动管理内存的一种机制;MRC即手动引用计数(Manual Reference Counting),需要开发者手动管理对象的内存,通过引用计数器来决定对象的生命周期 [^1][^2][^3]。 ARCMRC的区别主要体现在内存管理方式和开发者操作上。在MRC中,开发者需要手动管理对象的引用计数,当创建一个对象时,引用计数加1,当不再使用该对象时,需要手动调用`release`方法使引用计数减1,当引用计数为0时,对象被释放。例如在MRC下的`dealloc`方法中,需要释放自身的实例变量、移除观察者、停止timer、移除通知、代理置空等,并且一定要在最后写`[super dealloc];` 。而在ARC下,编译器会自动插入内存管理的代码,系统会帮助释放对象所包含的实例变量,但有些对象仍需开发者手动释放,如Core Foundation框架下的一些对象,同时也需要手动进行通知中观察者的移除、代理置空、停止timer等操作 [^2]。 在使用场景方面,对于新项目开发,建议使用ARC,因为它能减少开发者手动管理内存的工作量,降低内存泄漏的风险,提高开发效率。而对于一些老项目,可能由于历史原因采用了MRC,如果要将其迁移到ARC,需要提前让团队成员了解代码迁移的方法,并且在团队层面做好意识和能力上的准备,否则后续开发可能会出现问题 [^1]。 以下是ARCMRC下不同操作的代码示例: #### MRC下`dealloc`方法示例 ```objc - (void)dealloc { // 释放自身的实例变量 [_myObject release]; // 移除观察者 [[NSNotificationCenter defaultCenter] removeObserver:self]; // 停止timer [_myTimer invalidate]; _myTimer = nil; // 代理置空 self.delegate = nil; [super dealloc]; } ``` #### ARC下手动释放Core Foundation对象示例 ```objc CFStringRef cfString = CFStringCreateWithCString(kCFAllocatorDefault, "Hello", kCFStringEncodingUTF8); // 使用cfString // ... // 手动释放Core Foundation对象 CFRelease(cfString); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值