-observeValueForKeyPath:ofObject:change:context: message was received but not handled.

本文详细解析了KVO(Key-Value Observing)机制中的报错问题,特别是当同一对象上重复添加监听时出现的错误,并提供了解决方案。通过实例代码展示如何正确实现对象间的属性监听与响应,确保程序稳定运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

KVO报错
使用:A对象监听B对象中某个属性值的修改,在B对象上添加监听
添加监听:
[B addObserver:A forKeyPath:@”B的属性” options:NSKeyValueObservingOptionNew | NSKeyValueObservingOptionOld context:nil];

监听回调:
-(void)observeValueForKeyPath:(NSString )keyPath ofObject:(id)object change:(NSDictionary )change context:(void *)context
{
if ([@”属性名称” isEqualToString:keyPath]) {
//自己的逻辑处理
// object为B对象
//值的变化情况可以通过change获取
}
}

报错解决:
在同一个对象上仿佛的添加监听就会报该错误,解决办就是在添加监听前保证对象没有被监听。
-(void)dealloc // ARC模式下
{
[sectionModel removeObserver:self forKeyPath:@”isDone”];
}

07-01 11:39:12.926 2846 2846 W Looper : Slow dispatch took 124ms main h=com.android.server.notification.NotificationManagerService$WorkerHandler c=com.android.server.notification.NotificationManagerService$$ExternalSyntheticLambda0@8145441 m=0 07-01 11:39:12.928 6568 6568 D OMG_Observer: mScreenWidthDisplay = 1080, mScreenHeightDisplay = 2400, mRotation = 0, mOrient = 1 , mMiniSizeLimit = 660, mNormalSizeLimit =1800 07-01 11:39:12.933 1288 1865 D VRR [OTI]: handleContentIdleCheck [0.000000] 07-01 11:39:12.951 5245 5245 D BaseDepthController: setSurface: 07-01 11:39:12.951 5245 5245 D BaseDepthController: mWaitingOnSurfaceValidity: false 07-01 11:39:12.951 5245 5245 D BaseDepthController: mSurface: null 07-01 11:39:12.952 5245 5245 D LAUNCHER3: Launcher, handlePendingRequest: mPendingActivityRequestCode = -1, handled = false 07-01 11:39:12.954 5245 5245 D StateManager: goToState - fromState: Normal, toState: Normal, partial trace: 07-01 11:39:12.954 5245 5245 D StateManager: at com.android.launcher3.statemanager.StateManager.moveToRestState(StateManager.java:500) 07-01 11:39:12.954 5245 5245 D StateManager: at com.android.launcher3.statemanager.StateManager.moveToRestState(StateManager.java:491) 07-01 11:39:12.954 5245 5245 D StateManager: at com.android.launcher3.statemanager.StatefulActivity.onStop(StatefulActivity.java:119) 07-01 11:39:12.955 5245 5245 D StatsLog: LAUNCHER_ONSTOP 07-01 11:39:12.958 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.oplus.inner.view.ViewWrapper 07-01 11:39:12.958 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.color.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.oplus.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.color.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.oplus.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.color.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.oplus.inner.view.ViewWrapper 07-01 11:39:12.959 5245 5245 D ViewNative: java.lang.ClassNotFoundException: com.color.inner.view.ViewWrapper 07-01 11:39:12.976 6306 6329 I droid.apps.maps: Waiting for a blocking GC ProfileSaver
最新发布
07-17
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值