【发布时间】:2015-02-24 16:55:38
【问题描述】:
我自己的程序中有一个奇怪的错误。我目前正在开发视频编辑应用程序。我有一个 SongPicker 视图控制器,它显示来自用户音乐应用程序的所有歌曲。当用户选择一首歌曲时,会创建一个表示该歌曲的新对象 (MediaAsset)。当 SongPicker 用 Swift 编写,MediaAsset 用 Objective-C 编写时,它工作得非常好。但是我在 Swift 上完全重写了 MediaAsset,现在每次我尝试从 SongPicker 创建新的 MediaAsset 时,Xcode 都会抛出 EXC_BREAKPOINT (code=1, subcode=...) 并且我的应用程序崩溃了。
这里是用户选择歌曲时调用的代码:
private let mediaItems = MPMediaQuery.songsQuery().items as [MPMediaItem]
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath){
let item = filteredMediaItems[indexPath.row]
println("didSelectRowAtIndexPath")
println("item: \(item), url: \(item.assetURL.absoluteString)")
delegate?.songPickerViewController(self, didPickedAsset: MediaAsset(url: item.assetURL, type: .Audio))
}
它实际上生成输出到控制台:
didSelectRowAtIndexPath
item: <MPConcreteMediaItem: 0x174648340> 2369259457983598523, url: Optional("ipod-library://item/item.mp3?id=2369259457983598523")
然后转到 MediaAsset 构造函数,如下所示:
init(url: NSURL, type: MediaAssetType){
println("new MediaAsset with url \(url.absoluteString)")
self.url = url
self.asset = AVURLAsset(URL: url, options: [AVURLAssetPreferPreciseDurationAndTimingKey: true])
self.timeRange = CMTimeRangeMake(kCMTimeZero, self.asset.duration)
self.initialRate = CGFloat(max(self.asset.videoTrack!.nominalFrameRate / 30.0, 1.0))
self.rate = self.initialRate
self.type = type
}
它打印到控制台:
new MediaAsset with url Optional("ipod-library://item/item.mp3?id=2369259457983598523")
在这条线上它粉碎了:
从 AVURLAsset 创建资产的代码与我在旧的 ObjectiveC 类中的代码完全相同(它工作得非常好),所以问题不应该属于 AVFoundation。 有谁知道那次暗恋的原因是什么?作为更一般的问题,在哪些情况下会出现“EXC_BREAKPOINT (code=1, ...”?
编辑 删除此 println 语句后,我的应用程序仍然崩溃,但现在显示此汇编代码:
【问题讨论】:
-
是否开启了异常断点?如果关闭它们,问题是否仍然存在?
-
我关闭了异常断点
-
你启用了哪些断点?
-
我已经删除了所有断点