0

我是否应该能够在代理对象上设置观察者,更改代理对象指向的内容并且仍然能够观察真实对象的更改?

一个例子可以最好地解释这一点。考虑以下。

在标题中:

@interface MyController : NSObject {   

  MyWidgetModel * aProxyObject;

}

在初始化或从 NIB 方法唤醒中:

-(void)awakeFromNib {

 // Init the proxy object. Could be as an empty widget 

 [aProxyObject addObserver:self 
                forKeyPath:@"widgetName"
                   options:NSKeyValueObservingOptionNew 
                   context:nil];

}

更改对象的其他一些方法:

-(void)changeWidget:(MyWidgetModel *)aNewWidget {

  aProxyObject = aNewWidget;

}

这不会触发aNewWidget. 但是,如果我addObserver按如下方式在分配之后移动到,它会起作用:

-(void)changeWidget:(MyWidgetModel *)aNewWidget {

   [aProxyObject removeObserver:self forKeyPath:@"widgetName"];

   aProxyObject = aNewWidget;

   [aProxyObject addObserver:self 
                  forKeyPath:@"widgetName"
                     options:NSKeyValueObservingOptionNew 
                     context:nil];
}

我假设第一种情况不起作用是因为观察者正在观察代理对象引用的内存指针,并且由于在添加代理观察者时没有对象,所以没有什么可观察的。但是,如果我初始化一个小部件并观察它,然后分配代理对象aNewWidget,它仍然不会观察到更改,除非我在分配后添加观察者(当然需要在对象更改时删除观察者)。

另外,如果aNewWidget被破坏,在这种情况下会发生什么?因为观察者在代理上,这是否否定了在销毁对象之前移除观察者的需要?(我认为它没有)。

理想情况下,我希望能够在代理上设置观察者并交换我想要代理对象的任何小部件引用,而不必担心添加和删除观察者,除非MyController类消失,在这种情况下我可以处理在 dealloc 中移除观察者。

任何帮助/评论/建议表示赞赏。

4

1 回答 1

0

keyPath 必须符合 KVC。所以这里是代码:

@interface MyController : NSObject {   
  MyWidgetModel * aProxyObject;
}
@property (nonatomic, retain) MyWidgetModel * aProxyObject;

不要忘记在实现文件中合成它。然后使用此代码添加观察者:

[self addObserver:self 
            forKeyPath:@"aProxyObject"
               options:NSKeyValueObservingOptionNew 
               context:nil];

请检查我的编辑。我已将分配更改为保留。也许它对你更好。你应该尽量选择最适合你的。我只想说这在 KVO 中并不重要。

于 2011-02-04T19:15:01.370 回答