2

我正在使用 Apple 的 Instruments “分配”工具,并注意到当我在两个视图之间来回切换时,分配总是会增长。调查,我发现所有的内存都来自我的 UIViewController 的 UIView 的子视图的对象。

我检查了一下,我的 UIViewController 正在被释放,但显然 UIView 不是?我没有将 UIView 与 UIView 控制器分开保留。有人有想法么?

这是我编写的用于在视图之间切换的代码。

UISubViewController *viewController = [UIViewControllerFactory createViewController:viewControllerID];     // Creates and returns a UIViewController by ID

[currentViewController viewWillDisappear:YES];
[currentViewController.view removeFromSuperview];
[currentViewController viewDidDisappear:YES];

[viewController viewWillAppear:YES];
[self.view insertSubview:viewController.view atIndex:0];
[viewController viewDidAppear:YES];

self.currentViewController = viewController;
[viewController release];

编辑:
好的,因为担心我只是使用 ViewController 的 View 然后释放 ViewController,所以我尝试了一个实验,在该实验中我创建了一个新类,它是 NIB 中的文件所有者,但继承自 NSObject。

代码现在看起来像这样:

MyView *myView = [[MyView alloc] initWithNibName:@"myView"];

[currentView viewWillDisappear:YES];
[currentView.view removeFromSuperview];
[currentView viewDidDisappear:YES];

[myView viewWillAppear:YES];
[self.view insertSubview:myView.view atIndex:0];
[myView viewDidAppear:YES];

self.currentView = myView;
[myView release];

MyView 的初始化程序如下所示:

@interface MyView : NSObject {
    IBOutlet UIView *view;
    NSArray *nibTopLevelObjects;
}

@property (nonatomic, retain) UIView *view;

- (id)initWithNibName:(NSString *)nibName;

@end


@implementation MyView

@synthesize view;

- (id)initWithNibName:(NSString *)nibName {
    if (self = [super init]) {

        nibTopLevelObjects = [[NSBundle mainBundle] loadNibNamed:nibName owner:self options:nil];
        [nibTopLevelObjects retain];
    }
    return self;
}

- (void)dealloc {
    [view release];
    [nibTopLevelObjects release];

    view = nil;
    nibTopLevelObjects = nil;

    [super dealloc];
}

@end

每次换入和换出新视图时,我仍然会看到视图的内存泄漏。

有什么新想法吗?

4

2 回答 2

0

您的工厂返回一个 viewController 但您只是添加一个视图,而不是推送一个新控制器。为什么不在这种情况下创建一个视图?

您正在做的是不断覆盖 self.currentViewController ivar 而不释放它。您可能正在释放该视图控制器拥有的视图,但仅此而已。

currentViewController 是否定义为

@property (nonatomic, retain) UISubViewController* currentViewController;

也许?如果是这样,则存在与发布不匹配的保留 - 在覆盖它之前,您永远不会释放 self.currentViewController。如果你不使用self.它,即使属性是这样定义的,它也不会被保留。

于 2010-11-09T22:01:03.363 回答
0

您正确地删除了旧视图并添加了一个新视图。这意味着您在 SubViewController 中的某个地方错误地保留了视图,或者您正在模拟器而不是设备中进行测试。

您可以发布 SubViewController 的代码以查看其中发生了什么吗?

当您在真实设备上进行测试时,您会得到相同的结果吗?


PS Adam Eberbach 提出了一个公平的观点——你为什么要创建一个视图控制器只是为了窃取它的视图然后释放它?

于 2010-11-09T23:38:19.533 回答