首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >重写loadView会导致viewDidLoad和loadView每次出现VC时都会触发

重写loadView会导致viewDidLoad和loadView每次出现VC时都会触发
EN

Stack Overflow用户
提问于 2013-03-27 13:54:17
回答 2查看 400关注 0票数 0

我的观点是基于几个自定义的“根”UIViewController子类。我正在尝试为我的根VC子类设置一个自定义self.view。在那里,我正在做:

MyRootViewController_With_Scroll.h

代码语言:javascript
复制
// Import lowest level root VC
#import "MyRootViewController.h"
// my custom scroll view I want to use as self.view
@class MyScrollView;

@interface MyRootViewController_With_Scroll : MyRootViewController {

}

@property (strong) MyScrollView *view;

@end

MyRootViewController_With_Scroll.m

代码语言:javascript
复制
#import MyRootViewController_With_Scroll.h;

@interface MyRootViewController_With_Scroll ()

@end

@implementation MyRootViewController_With_Scroll

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{
self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
if (self) {
    // Custom initialization
}
return self;
}

- (void)loadView
{
    NSLog(@"loading view");
    CGRect windowSize = [UIScreen mainScreen].applicationFrame;
    MyScrollView *rootScrollView = [MyScrollView scrollerWithSize:windowSize.size];
    self.view = rootScrollView;

}

- (void)viewDidLoad
{
    [super viewDidLoad];
    // Do any additional setup after loading the view.
}

- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

// Getter and setter for self.view
- (MyScrollView *)view
{
    return (MyScrollView *)[super view];
}
- (void)setView:(MyScrollView *)view
{
    [super setView:view];
}

根据iOS6文档,在应用程序的整个生命周期中,viewDidLoad只能在每个视图控制器上触发一次。

我在这里做错什么了?是什么导致我的视图控制器反复调用loadView/viewDidLoad?奇怪的是,我的应用程序“主屏幕”VC只加载一次视图,但是它在导航传家宝中的所有后续视图每次出现都会触发loadView。怎么一回事?

编辑我已将属性更改为strong。同样的问题也会发生。

编辑2我已经停止重写loadView并且它仍然在发生。现在我真的很困惑。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-27 13:59:31

这是预期的行为。如果您从导航堆栈中弹出视图控制器,而其他任何控件都没有它们的引用,那么它们将被解除分配。因此,当它再次出现时,它将是一个新实例,因此它必须再次执行loadView等操作。在日志记录中包括self,每次都应该看到它是不同的对象。

您还将视图控制器的视图属性重新定义为weak --如果您正在重用视图控制器对象,那么当视图没有superview时,它就会被显示出来。

在iOS 6之前,导航堆栈中的视图控制器将在内存压力下卸载视图:

代码语言:javascript
复制
root --> VC1 --> VC2

VC2在屏幕上,接收到内存警告。VC1将卸载它的视图。当您从堆栈中弹出VC2时,VC1会再次调用loadView。这种事再也不会发生了。

但是,如果您已经弹出到VC1,并且没有对VC2的强引用,那么VC2就会被解除分配。当您将另一个VC2推到堆栈上时,这是一个新实例,loadView将再次被调用。您可能是在代码中创建这些新的VC2实例,因此您应该能够判断您正在创建一个新实例。

票数 2
EN

Stack Overflow用户

发布于 2013-03-27 14:01:34

那是因为您有弱视图属性。所以它总是被重新分配。此外,我认为您根本不需要覆盖view属性。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15660608

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档