小编典典

致命错误:展开可选值时意外发现nil

swift

UICollectionView在Swift 中使用了一个,但是当我尝试更改单元格标签的文本时得到了提示。

    func collectionView(collectionView: UICollectionView!, numberOfItemsInSection section: Int) -> Int
{
    return 5
}

func collectionView(collectionView: UICollectionView!, cellForItemAtIndexPath indexPath: NSIndexPath!) -> UICollectionViewCell!
{
    var cell = collectionView.dequeueReusableCellWithReuseIdentifier("title", forIndexPath: indexPath) as TitleCollectionViewCell
    // Next line: fatal error: unexpectedly found nil while unwrapping an Optional value
    cell.labelTitle.text = "This is a title"
    return cell
}

有人知道吗?

控制台上的警告屏幕截图


阅读 471

收藏
2020-07-07

共1个答案

小编典典

几乎可以肯定,您的重用标识符"title"不正确。

UITableView.h方法签名中我们可以看到dequeueReusableCellWithIdentifier,返回类型是
Implicitly Unwrapped Optional

func dequeueReusableCellWithIdentifier(identifier: String!) -> AnyObject! // Used by the delegate to acquire an already allocated cell, in lieu of allocating a new one.

这由以下的感叹号决定AnyObject

    AnyObject!

因此,首先要考虑的是什么是“隐式展开的可选”?

Swift编程语言告诉我们:

有时,从程序的结构中可以明显看出,在设置了可选值之后,可选值将始终具有该值。在这些情况下,删除每次访问可选值时都不需要检查和取消包装的值很有用,因为可以安全地假定它始终都具有值。

这些类型的可选定义为隐式解包的可选。您通过在要设置为可选的类型之后放置感叹号(String!)而不是问号(String?)来编写隐式展开的可选内容。

因此,从根本上讲,某些东西在某一时刻可能是零,但从某个时候开始再也不会为零。因此,我们通过将其作为未包装的值来节省一些麻烦。

在这种情况下,dequeueReusableCellWithIdentifier返回这样的值是有意义的。提供的标识符 必须已经用于注册单元以重用。
提供一个不正确的标识符,出队找不到它,运行时返回一个nil,永远不会发生。这是一个致命错误,应用程序崩溃,控制台输出显示:

fatal error: unexpectedly found nil while unwrapping an Optional value

底线:检查在.storyboard,Xib或代码中指定的单元重用标识符,并确保出队时它是正确的。

2020-07-07