OC_08_02 KVO

在ViewController.m文件里

#import "ViewController.h"
#import "Hero.h"
#import "Obsener.h"

@interface ViewController ()
{
    Hero *hero;//设置全局变量
    Obsener *obsener;

}
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    //KVO
    /*
     KVO的由来:在编程的过程中,我们经常需要判断目标是否发生变化,以便及时的做出对应的处理.此时苹果公司就提供了一种策略,即'OC运行时'提供了'KVO'技术.其中'KVO'是基于'KVC'实现的
     
     KVO的实现:
     1.要注册成观察者
     2.观察者定义KVO回调
     3.移除观察者
     */
    
    hero = [Hero new];
    [hero setValue:@100 forKey:@"_HP"];//KVC方式赋值
    
    
    obsener = [[Obsener alloc] initWithHero:hero];
    [hero setValue:@300 forKey:@"_HP"];
    
    [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(change:) userInfo:nil repeats:YES];
    
    //所有如果在主线程中可以不用写NSRunLoop做运行环境的语句,但是如果在非主线程中就要将NSTimer加入到改线程的NSRunLoop中,并启动NSRunLoop才行.  [[NSRunLoop currentRunLoop] run]
    
//    NSLog(@"man RunLoop = %@",[NSRunLoop mainRunLoop]);
   
    
}


-(void)change:(NSTimer *)timer
{
    NSLog(@"1111");
    NSUInteger _curHP = [[hero valueForKey:@"_HP"] integerValue];
    _curHP -= 50;
    if (_curHP<=0)
    {
        [hero setValue:@0 forKey:@"_HP"];
        [timer invalidate];
    }
    else
    {
        [hero setValue:[NSNumber numberWithInteger:_curHP] forKey:@"_HP"];
    }
    
}
- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end


在Hero.h文件里

@interface Hero : NSObject

{
    NSUInteger _HP;
}
@end


在Obsener.h文件里

#import <Foundation/Foundation.h>
#import "Hero.h"

@interface Obsener : NSObject

@property(nonatomic,retain)Hero *hero;

-(id)initWithHero:(Hero *)hero;

@end


在Obsensr.m文件里

#import "Obsener.h"

@implementation Obsener

-(id)initWithHero:(Hero *)hero
{

    if (self = [super init])
    {
        self.hero = hero;
        //注册监听者
        /*
         NSKeyValueObservingOptionNew 把更改之后的值提供给观察者的回调方法  p225
         NSKeyValueObservingOptionOld 把更改之前的值提供给观察者的回调方法
         NSKeyValueObservingOptionInitial 把初始化的值提供给观察者的回调方法,一旦注册,立马就会调用一次,通常它会带有新值,而不会带有旧值
         NSKeyValueObservingOptionPrior
         */
        [self.hero addObserver:self forKeyPath:@"_HP" options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];
        
        
    }
    return self;
}

//定义KVO回调
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context
{
    NSLog(@"change = %@",change);
    /*
     change是一个字典  包含的key如下 p226
     NSKeyValueChangeKindKey
     NSKeyValueChangeNewKey   新值
     NSKeyValueChangeOldKey   旧值
     NSKeyValueChangeIndexesKey
     NSKeyValueChangeNotificationIsPriorKey
     */
    
}

//移除监听者
-(void)dealloc
{
   /*
    NSObject类定义了一个方法叫做dealloc,当对象没有拥有者并且内存要被回收时,系统会自动调用dealloc方法.dealloc的责任是释放对象自己的内存,释放所有它控制的资源,包括释放所有实例变量的所有权
    */

    [self.hero removeObserver:self forKeyPath:@"_HP"];
    NSLog(@"I am die");
    
}
@end

Flutter和Objective-C(简称OC)都是开发移动应用程序的技术,但它们在很多方面有着不同的特点。 首先,Flutter是一种跨平台的移动应用开发框架,由谷歌开发。它使用Dart语言编写,具有热重载、响应式UI框架和丰富的UI组件等特点。Flutter的一大优势是可以同时在iOS和Android平台上开发应用程序,并且拥有高性能和良好的用户体验。Flutter也支持使用原生代码进行集成,因此可以很好地与Objective-C进行交互。 Objective-C是一种面向对象的编程语言,主要用于iOS和macOS平台的应用程序开发。Objective-C采用了一种称为KVO(Key-Value Observing)的机制,允许对象对属性和值的变化进行观察和响应。通过注册观察者,当被观察对象的属性发生变化时,观察者可以接收到通知并执行相应的操作。KVO是一种非常强大的工具,可以用于实现对象之间的数据绑定和通信。 在使用Flutter开发应用时,可以与Objective-C进行集成,并利用Objective-C提供的KVO机制来实现对Flutter应用内部变量的监视和响应。这可以通过在Flutter与Objective-C之间建立桥接来实现,从而达到在Flutter应用中使用KVO的目的。 总的来说,Flutter和Objective-C KVO是两种不同的技术,Flutter是一个跨平台的移动应用开发框架,而Objective-C KVO是一种可以用于观察和响应对象属性变化的机制。在合适的场景下,可以通过Flutter与Objective-C进行集成,从而利用KVO机制来实现对Flutter应用内部变量的监视和响应。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值