所以我为我的学校做了一个rss阅读器,并完成了代码。我运行了测试,它给了我这个错误。下面是它引用的代码:

- (UITableViewCell *)tableView:(UITableView *)tableView 
         cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    static NSString *CellIdentifier = @"Cell";
    UITableViewCell *cell = 
     [tableView dequeueReusableCellWithIdentifier:CellIdentifier 
                                     forIndexPath:indexPath];
    if (cell == nil) {

        cell = 
         [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle  
                                reuseIdentifier:CellIdentifier];

    }

以下是输出中的错误:

2012-10-04 20:13:05.356 Reader[4390:c07] * Assertion failure in -[UITableView dequeueReusableCellWithIdentifier:forIndexPath:], /SourceCache/UIKit_Sim/UIKit-2372/UITableView.m:4460 2012-10-04 20:13:05.357 Reader[4390:c07] * Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'unable to dequeue a cell with identifier Cell - must register a nib or a class for the identifier or connect a prototype cell in a storyboard' * First throw call stack: (0x1c91012 0x10cee7e 0x1c90e78 0xb64f35 0xc7d14 0x39ff 0xd0f4b 0xd101f 0xb980b 0xca19b 0x6692d 0x10e26b0 0x228dfc0 0x228233c 0x228deaf 0x1058cd 0x4e1a6 0x4ccbf 0x4cbd9 0x4be34 0x4bc6e 0x4ca29 0x4f922 0xf9fec 0x46bc4 0x47311 0x2cf3 0x137b7 0x13da7 0x14fab 0x26315 0x2724b 0x18cf8 0x1becdf9 0x1becad0 0x1c06bf5 0x1c06962 0x1c37bb6 0x1c36f44 0x1c36e1b 0x147da 0x1665c 0x2a02 0x2935) libc++abi.dylib: terminate called throwing an exception

下面是它在错误屏幕上显示的代码:

int main(int argc, char *argv[])
{
    @autoreleasepool {
        return UIApplicationMain(argc, argv, nil, NSStringFromClass([AppDelegate class]));
    }
}

请帮助!


当前回答

在我的情况下,崩溃发生时,我调用deselectrowatindexpath:

这一行是[tableView deselectRowAtIndexPath:indexPath animated:YES];

把它改成[self。tableView deselectRowAtIndexPath:indexPath animated:YES];解决了我的问题!

希望这对大家有所帮助

其他回答

对某些人来说,这可能很愚蠢,但我明白了。我得到了这个错误,我的问题是,我试图使用静态单元格,但动态添加更多的东西。如果你调用这个方法,你的单元格需要是动态原型。选择storyboard中的单元格,在Attributes检查器下,第一个内容是“Content”,你应该选择动态原型,而不是静态原型。

你必须意识到,当使用接口生成器和创建包含一个单元格的Xib (nib)时,还创建了一个占位符,指向将被使用的类。意思是,当你在一个Xib文件中放置两个UITableViewCell时,你可能会遇到完全相同的麻烦,导致***断言失败....占位符机制不起作用,n会感到困惑。取而代之的是在一个Xib中放置不同的占位符。

最简单的解决方案(即使看起来有点简单)是每次在一个Xib中放置一个Cell。IB将为您创建一个占位符,然后所有工作都按照预期进行。但是这将直接导致额外的一行代码,因为您需要加载正确的nib/xib,并请求它所在的reuseIdentified Cell。 因此,下面的示例代码着重于在一个表视图中使用多个Cell标识符,断言失败是非常常见的。

// possibly above class implementation
static NSString *firstCellIdentifier = @"firstCellIdentifier";
static NSString *secondCellIdentifier = @"secondCellIdentifier";

// possibly in -(instancetype)init 
UINib *firstNib = [UINib nibWithNibName:@"FirstCell" bundle:nil];
[self.tableView registerNib:firstNib forCellReuseIdentifier:firstCellIdentifier];
UINib *secondNib = [UINib nibWithNibName:@"SecondCell" bundle:nil];
[self.tableView registerNib:secondNib forCellReuseIdentifier:secondCellIdentifier];

在一个UITableView中使用两个CellIdentifier的另一个麻烦是必须考虑行高和/或节高。两个单元格当然可以有不同的高度。

当为重用注册类时,代码看起来应该有所不同。

当单元格位于Storyboard而不是Xib中时,“简单解决方案”看起来也有很大不同。注意占位符。

还要记住,界面构建器文件有版本变化,需要设置为目标操作系统版本支持的版本。即使你很幸运,你在Xib中放置的特定功能自上一个IB版本以来没有改变,也没有抛出错误。因此,使用IB制作的Xib被设置为兼容iOS 13+,但用于在早期版本iOS 12.4上编译的目标也会导致麻烦,并可能以断言失败告终。

你正在使用dequeueReusableCellWithIdentifier:forIndexPath:方法。该方法的文档是这样说的:

重要提示:在调用此方法之前,必须使用registerNib:forCellReuseIdentifier:或registerClass:forCellReuseIdentifier:方法注册类或nib文件。

您没有为重用标识符“Cell”注册nib或类。

看看你的代码,你似乎期望dequeue方法返回nil,如果它没有一个单元格给你。对于这种行为,你需要使用dequeueReusableCellWithIdentifier::

UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

注意dequeueReusableCellWithIdentifier:和dequeueReusableCellWithIdentifier:forIndexPath:是不同的方法。前者和后者见医生。

如果你想了解为什么你想要使用dequeueReusableCellWithIdentifier:forIndexPath:,看看这个问答。

只是对答案的补充: 可能有一段时间你把所有的东西都设置对了,但你可能不小心在你的.xib中添加了一些其他的ui,比如UIButton: 只要删除额外的UI,它就能工作。

我有同样的问题,有同样的错误,对我来说,它是这样工作的:

[self.tableView registerNib:[UINib nibWithNibName:CELL_NIB_HERE bundle: nil] forCellReuseIdentifier:CELL_IDENTIFIER_HERE];

也许它会对其他人有用。