无效参数不满足: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 是从XBMessageViewControllerloadDataToTable 方法设置的。我能找到 senderId 的值的唯一原因是 nil 是您没有设置 jidStrsenderId 的值。

您需要设置jidStrsenderIdXBMessageViewController,其中jidStr 是接收者,senderId 是自己的用户。

希望这会有所帮助。

【讨论】:

【参考方案2】:

你需要像[self.collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"Cell"];这样注册你的班级

【讨论】:

为什么要注册?视图控制器的父类已经做了同样的事情。 我认为在 ChatMessagesController 中您将重新使用单元格,因此您要么正在注册,要么不使用 cellIdentifier 我不认为 Collecitonview 或其单元格存在问题,因为模型类的属性为 nil 我认为从日志中你应该检查 cellForItemAtIndexPath 吗?

以上是关于无效参数不满足:messageSenderId != nil的主要内容,如果未能解决你的问题,请参考以下文章

RestKit 映射无效参数不满足:managedObjectStore

UICollectionViewDiffableDataSource 崩溃:无效参数不满足:itemCount

AFHTTPRequestOperationManager urlstring 编码和无效参数不满足:URLString

无效参数不满足:nibNameMap != nil

NSInternalInconsistencyException: '无效参数不满足: !stayUp || CLClientIsBackgroundable(内部->fClient)'

pageViewController setViewControllers 因“无效参数不满足:[views count] == 3”而崩溃