Notification Once perfectly solves the initialization of some modules in application:didFinishLaunchingWithOptions
2192 단어 iOS
AppDelegate
, found many written in- application:didFinishLaunchingWithOptions:
The code in is just to get a call opportunity when the program starts, mostly for the initialization of some modules, such as:- (BOOL)application:(UIApplication *)application
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// ...
[RunModule setup];
[[Loca sharedInstance] setup];
// ...
return YES;
}
In fact, these codes can be fully exploitedNotification
The way to get it inside your own module, share a clever method:// RunModule.m
+ (void)load
{
__block id observer =
[[NSNotificationCenter defaultCenter]
addObserverForName:UIApplicationDidFinishLaunchingNotification
object:nil
queue:nil
usingBlock:^(NSNotification *note) {
[self setup]; // Do whatever you want
[[NSNotificationCenter defaultCenter] removeObserver:observer];
}];
}
explain: + load
Method called early enough __NSObserver *
object for external remove observers __block
is not added, it will capture nil It's worth noting that the notification is not sent until the
- application:didFinishLaunchingWithOptions:
call completes. By the way, here is a suggestion for AppDelegate to slim down: AppDelegate, as a delegate for program-level state changes, should only be used for routing and distribution. The specific logic implementation code should still be in a separate module. This file should be kept clean, except for
There should be no other methods outside the method.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
View의 레이아웃 방법을 AutoLayout에서 따뜻한 손 계산으로 하면 성능이 9.26배로 된 이야기이 기사는 의 15 일째 기사입니다. 어제는 에서 이었습니다. 손 계산을 권하는 의도는 없고, 특수한 상황하에서 계측한 내용입니다 화면 높이의 10 배 정도의 contentView가있는 UIScrollView 레이아...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.