草庐IT

ARC下AutoReleasePool的误区

全部标签

objective-c - ARC 和 CFRelease?

我有点困惑。我读过的所有地方都建议在使用ARC时,你仍然需要释放核心基础对象,这是有道理的,ARC不管理它们。但是,我有一个方法使用了一些CF方法/对象,我在这些方法/对象上使用了CFRelease,但随后导致应用程序崩溃。取消注释我的CFRelease解决了这个问题,但我假设我有内存泄漏?有人可以解释一下哪些东西需要发布,哪些不需要,或者这段代码还有什么问题吗?+(NSString*)fileExtensionForMimeType:(NSString*)type{CFStringRefmimeType=(__bridgeCFStringRef)type;CFStringRefuti

ios - 我应该在接口(interface)中声明变量还是在 objective-c arc 中使用属性?

方法一:@interfaceMyController:UIViewController{UILabel*myText;}@property(nonatomic,strong)UILabel*myText;方法二:@interfaceMyController:UIViewController@property(nonatomic,strong)UILabel*myText;方法三:@interfaceMyController:UIViewController{UILabel*myText;}我已经阅读了一些谈论此类内容的文章,但我仍然没有真正意识到我必须采用哪种方法。我还发现有人说方法1

objective-c - Target-Action 设计模式是否在 ARC 下变成了坏习惯?

多年来,我一直在遵循一种名为Target-Action的伟大模式,它是这样的:一个对象在调用的时候调用指定目标对象上的指定选择器。这在您需要对任意方法进行简单回调的许多不同情况下非常有用。这是一个例子:-(void)itemLoaded{[specifiedReceiverperformSelector:specifiedSelector];}在ARC下,现在发现做这样的事情突然变得很危险。Xcode抛出如下警告:PerformSelectormaycausealeakbecauseitsselectorisunknown当然,选择器是未知的,因为作为T​​arget-Action设计

ios - ARC下的IBOutlet和viewDidUnload

SOhere上也有类似的问题,但是我只想澄清一些在那里没有完全解释的事情。我理解所有代表和导出——实际上任何对“父”对象的引用,作为一个好公民并考虑一下对象图——应该将弱引用归零。由于在引用对象的保留计数达到零时将弱指针归零的性质自动降至零,这是否意味着现在不需要在viewDidUnload中将IBOutlets设置为零?所以,如果我这样声明我的导出:@property(nonatomic,weak)IBOutletUILabel*myLabel;下面的代码有没有效果?-(void)viewDidUnload{self.myLabel=nil;[superviewDidUnload];

ios - 未在 ARC 应用程序上调用 Dealloc

我有一个UIViewController,它被推到容器Controller上,然后弹出,使用分配工具,我可以看到ViewController随后被销毁。但是,永远不会到达Controller的dealloc中的断点。有谁知道为什么不调用dealloc?ARC是否可以在不调用dealloc的情况下销毁对象?另外,我已经禁用了NSZombies(有些人说这会导致dealloc不触发)。编辑:Dealloc做的不多,只是打印到控制台,它永远不会被调用:-(void)dealloc{NSLog(@"取消分配...");}我不能发布容器Controller——它是专有的而且太复杂了。Deallo

ios - 为什么 ARC 在 popViewController 之后不释放内存

我在UINavigationController中推送和弹出ViewController。我正在跟踪我的应用程序的内存消耗。在推送新的viewController时,内存消耗逐渐增加,但是当我使用[self.navigationControllerpopViewControllerAnimated:NO];弹出相同的ViewController时内存消耗没有减少,而是保持不变。特定的viewController可以被用户多次推送和弹出,这会导致应用程序在RAM中的高内存消耗。我应该怎么做才能优化我的内存消耗? 最佳答案 当你关闭一个

ios - @属性定义与 ARC : Is strong default now?

刚刚在新的xcode4.3.1上运行ARC重构工具,我注意到我的(非原子,保留)属性被替换为(非原子)而不是像以前的xcode中的(非原子,强)。此更改后我的代码似乎运行良好,所以我假设它无论如何都默认为strong,有人知道为什么ARC转换器发生了变化吗? 最佳答案 是的,strong是Xcode4.3及更高版本中的默认值。它记录在LLVMdocs中在Apple的指南中usingproperties和workingwithARC. 关于ios-@属性定义与ARC:Isstrongdef

iphone - 使用 ARC 的优点和缺点是什么?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭9年前。Improvethisquestion在iOS项目中使用新的自动引用计数(ARC)内存管理方式有哪些优点和缺点?使用iOS5.0SDK开发时可以选择不使用ARC吗?您是否建议为新项目使用ARC或手动引用计数(MRC)?使用ARC的应用程序能否在iOS5.0之前的操作系统版本上运行?

ios - 如何在 Xcode 4.2 中启用 ARC 项目范围

我有一个iOS应用程序,我想将其转换为使用ARC。我只想使用迁移工具,但在预览阶段它总是给我出错。我知道我可以在逐个文件的基础上使用-fobjc-arc编译器指令,但我想在整个项目上启用ARC,然后使用-fno-objc-arc关闭个别类。4.2的新项目可以默认使用ARC,所以一定要有个开关。谁能帮我把项目转换成ARC 最佳答案 "ARCisavailableinXcode4.2,currentlyinbeta,andonlywhencompilingwithClang(a.k.a."AppleLLVMcompiler").Thes

ios - KVO和ARC如何移除Observer

如何从ARC下的对象中删除观察者??我们是否只添加观察者而忘记删除它?如果我们不再手动管理内存,我们从哪里退出观察?例如,在ViewController上:[self.viewaddObserver:selfforKeyPath:@"self.frame"options:NSKeyValueObservingOptionNewcontext:nil];以前,我会在ViewController的dealloc方法中调用removeObserver:。 最佳答案 您仍然可以在ARC下实现-dealloc,这似乎是移除键值观察的合适位置。