我UICollectionView在Swift 中使用了一个,但是当我尝试更改单元格标签的文本时得到了提示。
UICollectionView
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 }
有人知道吗?
几乎可以肯定,您的重用标识符"title"不正确。
"title"
从UITableView.h方法签名中我们可以看到dequeueReusableCellWithIdentifier,返回类型是 Implicitly Unwrapped Optional :
UITableView.h
dequeueReusableCellWithIdentifier
func dequeueReusableCellWithIdentifier(identifier: String!) -> AnyObject! // Used by the delegate to acquire an already allocated cell, in lieu of allocating a new one.
这由以下的感叹号决定AnyObject:
AnyObject
AnyObject!
因此,首先要考虑的是什么是“隐式展开的可选”?
Swift编程语言告诉我们:
有时,从程序的结构中可以明显看出,在设置了可选值之后,可选值将始终具有该值。在这些情况下,删除每次访问可选值时都不需要检查和取消包装的值很有用,因为可以安全地假定它始终都具有值。 这些类型的可选定义为隐式解包的可选。您通过在要设置为可选的类型之后放置感叹号(String!)而不是问号(String?)来编写隐式展开的可选内容。
有时,从程序的结构中可以明显看出,在设置了可选值之后,可选值将始终具有该值。在这些情况下,删除每次访问可选值时都不需要检查和取消包装的值很有用,因为可以安全地假定它始终都具有值。
这些类型的可选定义为隐式解包的可选。您通过在要设置为可选的类型之后放置感叹号(String!)而不是问号(String?)来编写隐式展开的可选内容。
因此,从根本上讲,某些东西在某一时刻可能是零,但从某个时候开始再也不会为零。因此,我们通过将其作为未包装的值来节省一些麻烦。
在这种情况下,dequeueReusableCellWithIdentifier返回这样的值是有意义的。提供的标识符 必须已经用于注册单元以重用。 提供一个不正确的标识符,出队找不到它,运行时返回一个nil,永远不会发生。这是一个致命错误,应用程序崩溃,控制台输出显示:
fatal error: unexpectedly found nil while unwrapping an Optional value
底线:检查在.storyboard,Xib或代码中指定的单元重用标识符,并确保出队时它是正确的。