由init、loadView、viewDidLoad、viewDidUnload、dealloc的关系说起
init方法
在init方法中实例化必要的对象(遵从LazyLoad思想)
init方法中初始化ViewController本身
loadView方法
当view需要被展示而它却是nil时,viewController会调用该方法。不要直接调用该方法。
如果手工维护views,必须重载重写该方法
如果使用IB维护views,必须不能重载重写该方法
loadView和IB构建view
你在控制器中实现了loadView方法,那么你可能会在应用运行的某个时候被内存管理控制调用。 如果设备内存不足的时候, view 控制器会收到didReceiveMemoryWarning的消息。 默认的实现是检查当前控制器的view是否在使用。 如果它的view不在当前正在使用的view hierarchy里面,且你的控制器实现了loadView方法,那么这个view将被release, loadView方法将被再次调用来创建一个新的view。
viewDidLoad方法
viewDidLoad 此方法只有当view从nib文件初始化的时候才被调用。
重载重写该方法以进一步定制view
在iPhone OS 3.0及之后的版本中,还应该重载重写viewDidUnload来释放对view的任何索引
viewDidLoad后调用数据Model
viewDidUnload方法
当系统内存吃紧的时候会调用该方法(注:viewController没有被dealloc)
内存吃紧时,在iPhone OS 3.0之前didReceiveMemoryWarning是释放无用内存的唯一方式,但是OS 3.0及以后viewDidUnload方法是更好的方式
在该方法中将所有IBOutlet(无论是property还是实例变量)置为nil(系统release view时已经将其release掉了)
在该方法中释放其他与view有关的对象、其他在运行时创建(但非系统必须)的对象、在viewDidLoad中被创建的对象、缓存数据等 release对象后,将对象置为nil(IBOutlet只需要将其置为nil,系统release view时已经将其release掉了)
一般认为viewDidUnload是viewDidLoad的镜像,因为当view被重新请求时,viewDidLoad还会重新被执行
viewDidUnload中被release的对象必须是很容易被重新创建的对象(比如在viewDidLoad或其他方法中创建的对象),不要release用户数据或其他很难被重新创建的对象
dealloc方法
viewDidUnload和dealloc方法没有关联,dealloc还是继续做它该做的事情
看到以下的代码
- (void)viewDidUnload {
self.detailViewController = nil;
self.languageNames = nil;
self.languageCodes = nil;
}
- (void)dealloc {
[detailViewController release];
[languageNames release];
[languageCodes release];
[super dealloc];
}
如果是先调用viewDidUnload后再调用dealloc, 那么languageNames都已经是nil了,再掉release有什么意义呢?
原因似乎是, 对一个viewcontroller来说,它的数据的初始化在init中,而它管理的view采用了lazy load的方式,也就是有需要的时候才会载入, 所以跟view相关的数据可以在viewDidLoad(也就是在view被载入的时候)进行初始化。当内存紧张的时候, ios会销毁点一些view, 通过调用viewDidUnload (里面一般也只是把跟view相关的数据设为nil), 但这个时候viewcontroller本身还在, 所以它的dealloc不会被调用,除非是到了viewcontroller也被销毁的时候
转:http://hi.baidu.com/wwssttt/item/8ae60025d53c16d0a517b6d7
相关推荐
此外,如果视图控制器还持有其他对象的引用,你也需要在`dealloc`方法中释放它们,对于iOS 2.x,确保在调用`super dealloc`之前完成这一操作。 总结一下这三个方法的使用流程: 1. 视图需要时,系统会调用`loadView...
2. **是否真的要在dealloc方法中调用IBOutlet的setter?** - dealloc方法是对象被销毁时调用的最后一个方法。通常建议在dealloc方法中将IBOutlet设为nil或释放其持有的资源,但不应该直接调用setter方法。因为一旦...
`viewDidUnload`和`dealloc`并不直接关联,即使视图已卸载,`dealloc`仍会继续释放其他非视图相关资源。 MVC(Model-View-Controller)是软件设计模式之一,广泛应用于Objective-C中的Cocoa框架。在Cocoa中,MVC...
4. `viewWillAppear`方法在视图即将显示在屏幕上之前调用,此时视图的布局和动画设置已经完成。默认情况下,这个方法不执行任何操作,但开发者可以在这里执行一些准备显示的逻辑,如启动动画或者更新界面元素。 5. ...
1. UIViewController调用顺序:`initWithNibName:bundle:` -> `loadView` -> `viewDidLoad` -> 使用视图 -> `viewDidUnload` -> `dealloc`。`initWithNibName:bundle:`初始化,`loadView`加载视图,`viewDidLoad`...
1. `alloc`与`dealloc`和`release`的关系: 在Objective-C中,`alloc`用于分配内存并初始化对象,而`dealloc`是对象的析构函数,用于释放对象占用的内存。`release`是降低对象引用计数的方法。与`alloc`语义相反的...
`viewDidUnload`在内存紧张时调用,用于释放视图资源;自定义时,应根据需求在这些方法中添加相应的工作。 19. `didReceiveMemoryWarning`在系统认为内存不足时调用,默认操作是释放可复用的非关键资源,自定义时,...
`viewDidLoad`, `viewWillAppear`, `viewDidUnload`, `dealloc`等方法在不同的生命周期阶段被调用。例如,`viewDidLoad`在视图加载完成后调用,适合进行初始化设置;`dealloc`在对象被销毁前调用,应在此释放资源。 ...
- `dealloc`:视图控制器被释放前调用,释放资源。 9. **Objective-C内存管理** Objective-C使用引用计数来管理内存,`retain`、`release`、`autorelease`用于控制对象生命周期。自动释放池在当前作用域结束时...
- **viewDidUnload**:视图卸载前调用。 ### 28. 内存管理 - **ARC**:自动引用计数机制,简化了内存管理。 - **MRC**:手动引用计数机制,需要手动管理内存。 ### 29. GCD - **GCD**:Grand Central Dispatch,...