无效参数不满足:messageSenderId != nil
Posted
技术标签:
【中文标题】无效参数不满足:messageSenderId != nil【英文标题】:Invalid parameter not satisfying: messageSenderId != nil 【发布时间】:2015-09-02 07:16:10 【问题描述】:我将来自 Cocoapods 的 'XBChatModule'
Library 集成到我的项目中。
当我第一次运行代码时,它通过抛出以下错误-[XBMessage messageHash]: unrecognized selector sent to instance 使应用程序崩溃,并通过更改XBMessage.m
文件解决了它,如下所示
XBMessage.m
- (NSUInteger)messageHash
return self.hash;
但这会产生新的问题
Assertion failure in -[ChatMessagesController collectionView:cellForItemAtIndexPath:], /Users/Neelacharya/Harshit/LIve Projects/Project/V1/Source/Project/Pods/JSQMessagesViewController/JSQMessagesViewController/Controllers/JSQMessagesViewController.m:452
Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Invalid parameter not satisfying: messageSenderId != nil'
*** First throw call stack:
(
0 CoreFoundation 0x000000011161ca75 __exceptionPreprocess + 165
1 libobjc.A.dylib 0x00000001112b1bb7 objc_exception_throw + 45
2 CoreFoundation 0x000000011161c8da +[NSException raise:format:arguments:] + 106
3 Foundation 0x000000010edcfb6f -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 195
4 CinchGaming 0x000000010d7be3c5 -[JSQMessagesViewController collectionView:cellForItemAtIndexPath:] + 693
5 CinchGaming 0x000000010d7f5f6d -[XBMessageViewController collectionView:cellForItemAtIndexPath:] + 141
6 UIKit 0x00000001102b9fab -[UICollectionView _createPreparedCellForItemAtIndexPath:withLayoutAttributes:applyAttributes:] + 244
7 UIKit 0x00000001102bb6e4 -[UICollectionView _updateVisibleCellsNow:] + 3445
8 UIKit 0x00000001102bf391 -[UICollectionView layoutSubviews] + 243
9 UIKit 0x000000010fd041c3 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 521
10 QuartzCore 0x000000010f9d2c58 -[CALayer layoutSublayers] + 150
11 QuartzCore 0x000000010f9c787e _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 380
12 QuartzCore 0x000000010f9c76ee _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24
13 QuartzCore 0x000000010f93536e _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 242
14 QuartzCore 0x000000010f936482 _ZN2CA11Transaction6commitEv + 390
15 QuartzCore 0x000000010f936aed _ZN2CA11Transaction17observer_callbackEP19__CFRunLoopObservermPv + 89
16 CoreFoundation 0x0000000111551507 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
17 CoreFoundation 0x0000000111551460 __CFRunLoopDoObservers + 368
18 CoreFoundation 0x0000000111547293 __CFRunLoopRun + 1123
19 CoreFoundation 0x0000000111546bc6 CFRunLoopRunSpecific + 470
20 GraphicsServices 0x0000000112796a58 GSEventRunModal + 161
21 UIKit 0x000000010fc8a580 UIApplicationMain + 1282
22 CinchGaming 0x000000010d67e463 main + 115
23 libdyld.dylib 0x0000000111b4e145 start + 1
24 ??? 0x0000000000000001 0x0 + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
我了解崩溃的原因是成员 messageSenderId 在 JSQMessagesViewController.m 文件的第 452 行为 nil。但我不知道它为什么会发生以及如何解决它。
我还通过Github 向作者报告了问题,但没有得到回复。
如果您能帮我解决问题,我将不胜感激。
【问题讨论】:
好的,所以messageSenderId == nil
。现在您需要弄清楚通常会填充它的内容。您还需要知道为什么必须提供XBMessage messageHash
的实现(找到作者并询问他/她)。然而,对于 *** 来说,这有点宽泛。
好吧,当我看到示例代码时,它是旧版本的库,不需要实现我所做的上述方法,但是来自 cocoa pod 作为库的代码,需要该方法将要执行。我也将问题发布给了作者 (github.com/EugeneNguyen/XBChatModule/issues/2),但他没有回复。
【参考方案1】:
它认为应用程序在这一行崩溃了:
NSString *messageSenderId = [messageItem senderId];
NSParameterAssert(messageSenderId != nil);
当我深入研究时,我发现senderId
是从XBMessageViewController
的loadDataToTable
方法设置的。我能找到 senderId
的值的唯一原因是 nil 是您没有设置 jidStr
和 senderId
的值。
您需要设置jidStr
和senderId
和XBMessageViewController
,其中jidStr
是接收者,senderId
是自己的用户。
希望这会有所帮助。
【讨论】:
【参考方案2】:你需要像[self.collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"Cell"];
这样注册你的班级
【讨论】:
为什么要注册?视图控制器的父类已经做了同样的事情。 我认为在 ChatMessagesController 中您将重新使用单元格,因此您要么正在注册,要么不使用 cellIdentifier 我不认为 Collecitonview 或其单元格存在问题,因为模型类的属性为 nil 我认为从日志中你应该检查 cellForItemAtIndexPath 吗?以上是关于无效参数不满足:messageSenderId != nil的主要内容,如果未能解决你的问题,请参考以下文章
RestKit 映射无效参数不满足:managedObjectStore
UICollectionViewDiffableDataSource 崩溃:无效参数不满足:itemCount
AFHTTPRequestOperationManager urlstring 编码和无效参数不满足:URLString
NSInternalInconsistencyException: '无效参数不满足: !stayUp || CLClientIsBackgroundable(内部->fClient)'
pageViewController setViewControllers 因“无效参数不满足:[views count] == 3”而崩溃