iOS 有一种叫做通知的产生时间的功能.可以在一定的条件下处罚响应事件.通过nsnotificationcenter 获取通知对象,注册并且使用通知.面向对象的设计思想是把行为方法封装在一个对象中,以用来增加代码的复用性.这是这种分散的分装,增加了对象之间的相互关联,总是有很多的对象需要彼此的礼教以及相互操作.
一个简单的例子说明这种交互产生的对象之间的相互依赖:
有一个列表框,没当列表框的某一项被选中时会弹出一个对话框,对话框包含一个或者多个输入框,在输入完毕输入的文字要更新要再列表中显示,文字描述有点啰嗦.大家可以以qq微新好友列表为参考.
只是这几个ui空间之间交互逻辑九如此的麻烦与复杂.这种对象之间的相互关联与我们有的高度复用,高内聚低耦合的思想是不相符合的.并且ui控件之间势必需要相互了解操作.情况九回变得越来越难以控制.最终使得整个程序变得那一复用与维护.
通过通知中心:NSNotificationCenter可以很简单的解觉这个问题.在其他的开发中也回用相同的问题,这种处理机制的设计模式被称作为中介模式.每一个应用程序中都有一个通知中心的实例,专门负责协助不同对象之间的消息通知.任何一个对象都可以向通知中线发送通知(NSNOtification),描述自己在左什么.其他感兴趣的对象(observer)可以接受到通知,发生相应的变化.
通知中心nsnotificationcenter提供了方法来注册一个监听器(observer)
- (void)addObserver:(id)observer selector:(SEL)aSelector name:(NSString *)aName object:(id)anObject;
//observer :监听器,即谁要接受这个通知
aselector 收到通知后,回调监听器的这个方法,并把通知对象当做单参数出入
aname 通知的名称,若果为nil 那么无论通知名称是什么,监听器都能够收到这个通知
//anObjict : 通知发布者.如果为ANObjiect 和ANAMEWI 都为nil,监听器都收到所以的通知
//name 通知的名称
// obj: 通知的发布者
//block 收到对应的通知是,会回调这个
//blockqueue 决定了block 子那个操作队列中执行.日过传nil.默认在当前的操作队列中同步执行通知
一个完整的通知一般包含三个属性
-(nsstring *)name //通知的名称
- (id)objict //发布者(是谁要发布)
-(nsdictionary)userinfo //一些额外的信息(通过发布者传递接受者的信息内容)
初始化一个(Nsnotification)对象
发布通知:
一下以一个例子威力:
uiapplocation * application = [uiapplication sharedapplicaton];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(applicationWillResignActive:)name:UIApplicationWillResignActiveNotification object:application];
以上代码注册了一个通知,addObserver是接收通知的对象,通常为self,selector是接收到通知后要执行的操作,可以理解为操作事件,name是通知的名称,这里使用的是UIApplicationWillResignActiveNotification,意思是应用程序将要进入后台之前,object限定只接收来自哪些对象的通知,通常设为nil,你也可以写某些方法,让这个感兴趣的观察者执行某些方法.
-(void)applicationWillResignActive:(NSNotification *)notification //注: 这个方法可以写其他很多的响应方法(根据你自己的需求)
{
}
在上面这个方法中实现响应的操作就可以了。
这个过程就是当应用程序将要进入后台前(按下Home键)触发通知,然后执行applicationWillResignActive:notification方法完成一些操作。这个例子大家也许没有明白通知的注册过程,下面一个例子大家好好看哦:
appdelegata.m 中
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override point for customization after application launch.
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
[[NSNotificationCenter defaultCenter] addObserver: self
selector: @selector(callBack)
name: @"aa"
object: nil];
ViewController * view = [[ViewController alloc]init];
self.window.rootViewController = view;
self.window.backgroundColor = [UIColor whiteColor];
[self.window makeKeyAndVisible];
return YES;
}
- (void)callBack{
NSLog(@"this is Notification.");
}
viewconterllor中
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override point for customization after application launch.
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
[[NSNotificationCenter defaultCenter] addObserver: self
selector: @selector(callBack)
name: @"aa"
object: nil];
ViewController * view = [[ViewController alloc]init];
self.window.rootViewController = view;
self.window.backgroundColor = [UIColor whiteColor];
[self.window makeKeyAndVisible];
return YES;
}
- (void)callBack{
NSLog(@"this is Notification.");
}
- (void)viewDidLoad
{
[super viewDidLoad];
UIButton * button = [[UIButton alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];
button.backgroundColor = [UIColor redColor];
[button addTarget:self action:@selector(getNotofocation) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:button];
// Do any additional setup after loading the view, typically from a nib.
}
- (void)getNotofocation{
NSLog(@"get it.");
//发出通知
[[NSNotificationCenter defaultCenter] postNotificationName:@"aa"object:self];
}
}
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
// Override point for customization after application launch.
self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
[[NSNotificationCenter defaultCenter] addObserver: self
selector: @selector(callBack)
name: @"aa"
object: nil];
ViewController * view = [[ViewController alloc]init];
self.window.rootViewController = view;
self.window.backgroundColor = [UIColor whiteColor];
[self.window makeKeyAndVisible];
return YES;
}
- (void)callBack{
NSLog(@"this is Notification.");
}