【发布时间】:2015-05-01 15:20:34
【问题描述】:
最近,我一直在研究一个应用程序。该应用程序的目标是向您展示您在通知中心的“今日”视图中拍摄的最后 10 张照片等。该应用程序在 iOS 模拟器中完美运行,但是一旦我将它放在真实设备上进行测试,它就会失败。它返回错误:
fatal error: Unexpected nil while unwrapping an Optional value
通常这很容易修复,因为 XCode 会突出显示返回 nil 的代码并让您有机会修复它。在这种情况下,我的代码都没有突出显示。相反,它突出显示了线程 1 中的一行(这是正确的术语吗?线程 1?),如下所示: 另请注意,突出显示的线上方是线
; function signature specialization <Arg[0] = Exploded, Arg[1] = Exploded of Swift.(_fatalErrorMessage (Swift.StaticString, Swift.StaticString, Swift.StaticString, Swift.UInt) -> ()).(closure #2)
我在图片中包含了这一行,因为它的“fatalErrorMessage”部分。我怀疑这可能会提示我错误,但我不知道这意味着什么。我还没有到理解的地步。
另外,经过一番思考,我在 viewDidLoad() 函数处设置了一个断点,希望能跟踪任何 nil 值,但代码似乎永远也达不到这一点。好像我的代码都没有运行。
有没有人遇到过这样的问题/理解错误代码(如果是这样的话)的含义吗?我现在很绝望,所以我在这里。
谢谢, CodeIt
编辑: 我在 viewDidLoad 函数中放置了一条 println 行,以仔细检查它是否正在运行。 println 函数运行并正确输出,所以我想我可能只是以某种方式弄乱了我的断点。无论如何 - 代码运行,但它仍然没有突出显示我的任何导致 nil 值的代码。
编辑 2: 根据要求,我插入了部分代码。请记住,如果您愿意,此代码是“初稿”,我还没有开始清理它。我只是想让它工作:
@IBOutlet weak var currentPosLabel: UILabel!
var currentImgPos = 0
@IBOutlet weak var imageView: UIImageView!
var images: NSMutableArray!
var totalImageCountNeeded: Int!
func fetchPhotos() {
images = NSMutableArray()
totalImageCountNeeded = 10
self.fetchPhotoAtIndexFromEnd(0)
}
func fetchPhotoAtIndexFromEnd(index: Int) {
let imgManager = PHImageManager.defaultManager()
var requestOptions = PHImageRequestOptions()
requestOptions.synchronous = true
var fetchOptions = PHFetchOptions()
fetchOptions.sortDescriptors = [NSSortDescriptor(key: "creationDate", ascending: false)]
if let fetchResult = PHAsset.fetchAssetsWithMediaType(PHAssetMediaType.Image, options: fetchOptions) {
if fetchResult.count > 0 {
imgManager.requestImageForAsset(fetchResult.objectAtIndex(fetchResult.count - 1 - index) as? PHAsset, targetSize: view.frame.size, contentMode: PHImageContentMode.AspectFill, options: requestOptions, resultHandler: { (image, _) in
self.images.addObject(image)
if index + 1 < fetchResult.count && self.images.count < self.totalImageCountNeeded {
self.fetchPhotoAtIndexFromEnd(index + 1)
} else {
println("Completed array: \(self.images)")
}
})
}
}
}
override func viewDidLoad() {
super.viewDidLoad()
}
override func viewDidAppear(animated: Bool) {
// NOTE: I am calling the fetchPhotos() function here since earlier in my debugging I thought the problem may be that I was calling it too early in the viewDidLoad function. It an incorrect theory, but it was worth a try.
fetchPhotos()
if images.count > 0 {
imageView.image = images[1] as? UIImage
}
}
我删除了一些我知道没有理由导致我的错误的代码部分,例如@IBActions、didReceiveMemoryWarning() 等。
【问题讨论】:
-
明确一点,你设置了异常断点?
-
@Allan Chau,原来我只是通过一行代码点击侧边栏添加断点。这是异常断点吗?我不这么认为,但我不确定。我对不同类型的断点不是很熟悉。我刚刚尝试将异常断点设置为所有异常,但它停在同一区域。
-
你找到解决办法了吗??即使我面临同样的问题..!!
-
@IrshadQureshi (这是对您问题的相当晚的答复。抱歉!)接受的答案是可能解决了我的问题的答案。但是,在 Swift 1.2 到 Swift 2.1 更新之后,我执行了在接受的答案中看到的步骤。在此更新中,XCode 可能会改变任何东西,所以我不确定接受的答案是否真的解决了问题。然而,这是最有可能的答案。我建议您尝试一下,然后告诉我们它对您的效果。
标签: ios swift null ios-simulator