- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在一个应用程序上安装了 Crashlytics,我发现了一个影响某些用户的错误,我无法自己复制它。
错误是 EXC_BAD_ACCESS KERN_INVALID_ADDRESS
。我看了this post re: EXC_BAD_ACCESS ,但我不知道应该在崩溃日志中的哪个位置查找问题。
根据以下崩溃日志,是否有我应该放置断点以检查 nils 的地方?
Thread 0:
Crashed: com.apple.main-thread
EXC_BAD_ACCESS KERN_INVALID_ADDRESS 0x00000000154d9050
raw
0 libobjc.A.dylib objc_msgSend + 16
1 libAVFAudio.dylib -[AVAudioPlayer(AVAudioPlayerPriv) finishedPlaying:] + 92
2 Foundation __NSThreadPerformPerform + 340
3 CoreFoundation __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 24
4 CoreFoundation __CFRunLoopDoSources0 + 540
5 CoreFoundation __CFRunLoopRun + 724
6 CoreFoundation CFRunLoopRunSpecific + 384
7 GraphicsServices GSEventRunModal + 180
8 UIKit UIApplicationMain + 204
9 My App AppDelegate.swift line 19 main
10 libdyld.dylib start + 4
Thread 1: com.apple.libdispatch-manager
0 libsystem_kernel.dylib kevent_qos + 8
1 libdispatch.dylib _dispatch_mgr_invoke + 232
2 libdispatch.dylib _dispatch_source_invoke + 50
Thread 2: com.twitter.crashlytics.ios.MachExceptionServer
0 My App CLSProcess.c line 374 CLSProcessRecordAllThreads
1 My App CLSProcess.c line 374 CLSProcessRecordAllThreads
2 My App CLSProcess.c line 398 CLSProcessRecordAllThreads
3 My App CLSHandler.m line 24 CLSHandler
4 My App CLSMachException.c line 443 CLSMachExceptionServer
5 libsystem_pthread.dylib _pthread_body + 156
6 libsystem_pthread.dylib _pthread_body + 154
7 libsystem_pthread.dylib thread_start + 4
Thread 3: com.apple.NSURLConnectionLoader
0 libsystem_kernel.dylib mach_msg_trap + 8
1 libsystem_kernel.dylib mach_msg + 72
2 CoreFoundation __CFRunLoopServiceMachPort + 196
3 CoreFoundation __CFRunLoopRun + 1032
4 CoreFoundation CFRunLoopRunSpecific + 384
5 CFNetwork +[NSURLConnection(Loader) _resourceLoadLoop:] + 412
6 Foundation __NSThread__start__ + 1000
7 libsystem_pthread.dylib _pthread_body + 156
8 libsystem_pthread.dylib _pthread_body + 154
9 libsystem_pthread.dylib thread_start + 4
Thread 4: com.apple.CFSocket.private
0 libsystem_kernel.dylib __select + 8
1 CoreFoundation __CFSocketManager + 648
2 libsystem_pthread.dylib _pthread_body + 156
3 libsystem_pthread.dylib _pthread_body + 154
4 libsystem_pthread.dylib thread_start + 4
Thread 5: com.apple.coreaudio.AQClient
0 libsystem_kernel.dylib mach_msg_trap + 8
1 libsystem_kernel.dylib mach_msg + 72
2 CoreFoundation __CFRunLoopServiceMachPort + 196
3 CoreFoundation __CFRunLoopRun + 1032
4 CoreFoundation CFRunLoopRunSpecific + 384
5 AudioToolbox GenericRunLoopThread::Entry(void*) + 164
6 AudioToolbox CAPThread::Entry(CAPThread*) + 124
7 libsystem_pthread.dylib _pthread_body + 156
8 libsystem_pthread.dylib _pthread_body + 154
9 libsystem_pthread.dylib thread_start + 4
Thread 6: Thread
0 libsystem_kernel.dylib __workq_kernreturn + 8
1 libsystem_pthread.dylib _pthread_wqthread + 1284
2 libsystem_pthread.dylib start_wqthread + 4
Thread 7: Thread
0 libsystem_kernel.dylib __workq_kernreturn + 8
1 libsystem_pthread.dylib _pthread_wqthread + 1284
2 libsystem_pthread.dylib start_wqthread + 4
Thread 8: Thread
0 libsystem_kernel.dylib __workq_kernreturn + 8
1 libsystem_pthread.dylib _pthread_wqthread + 1284
2 libsystem_pthread.dylib start_wqthread + 4
Thread 9: Thread
0 libsystem_kernel.dylib __workq_kernreturn + 8
1 libsystem_pthread.dylib _pthread_wqthread + 1284
2 libsystem_pthread.dylib start_wqthread + 4
更新:
在Rog的建议下,我查看了调用AVAudioPlayer的方法。
我有一个名为 MP3Player
的类。它有两种初始化方法:
1) 播放单个文件
init(fileName: String) {
// Need to get location of file in bundle
let fileNamePath: String = NSBundle.mainBundle().pathForResource(fileName, ofType: "")!
// Then add the filename to the tracks array of strings
tracks.append(fileNamePath)
super.init()
queueTrack()
}
2) 播放一系列文件
init(arrayOfMP3FileNames: NSArray) {
for fileName in arrayOfMP3FileNames {
// get the path of the file...
let fileNamePath: String = NSBundle.mainBundle().pathForResource(fileName as? String, ofType: "")!
// ...and add it to the tracks array
tracks.append(fileNamePath)
}
super.init()
queueTrack()
}
queueTrack
方法似乎包含了我的部分问题:
func queueTrack() {
// I have no idea what possessed me to put this in, but I think it's the majority
// of my problem
// ** TOOK FOLLOWING 2 LINES OUT **
// if (player != nil) {
// player = nil
// }
let url = NSURL.fileURLWithPath(tracks[currentTrackIndex] as String)
do {
player = try AVAudioPlayer(contentsOfURL: url) // Thread 1: breakpoint 1.1
player?.delegate = self
player?.prepareToPlay()
} catch let error as NSError {
NSLog("Unresolved error \(error.debugDescription)")
// SHOW ALERT OR SOMETHING
}
}
在断点导航器中,我为“所有异常”添加了异常断点。如果我在当前正在播放声音的同时播放另一个声音,我会在 do {}
语句的第一行出现异常。它不会在模拟器或设备上崩溃,但我想我需要清理它,这样我就不会出现异常。对于解决此问题的任何建议,我们将不胜感激。
最佳答案
在 Rog 的建议下,我查看了我的 MP3Player 类如何播放 MP3 文件,并发现从该类的初始化器调用的方法正在初始化 MP3 播放器实例。当我最初写它时,我以为我是在“清理”,但实际上我是在创造潜在崩溃的根源。
func queueTrack() {
// I have no idea what possessed me to put this in, but I think it's the majority
// of my problem
// ** TOOK FOLLOWING 2 LINES OUT **
// if (player != nil) {
// player = nil
// }
let url = NSURL.fileURLWithPath(tracks[currentTrackIndex] as String)
do {
player = try AVAudioPlayer(contentsOfURL: url) // Thread 1: breakpoint 1.1
player?.delegate = self
player?.prepareToPlay()
} catch let error as NSError {
NSLog("Unresolved error \(error.debugDescription)")
// SHOW ALERT OR SOMETHING
}
}
关于ios - 确定使用 Crashlytics 记录的 "EXC_BAD_ACCESS KERN_INVALID_ADDRESS"的根本原因,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33859346/
我遇到了一些应用程序崩溃的问题,我需要一些指导才能修复它。我有一个带有主视图和模态视图的应用程序,非常类似于默认的翻转实用模板。当我第一次运行该应用程序时,一切都运行良好,包括模态视图。但是,当我返回
UPDATE: I updated the correction of my definition of Realm, I still get the error. I'm using Swi
我正在尝试用带有c的sqlite3创建一个CGI可执行文件。但我收到错误exc_badd_access,我不知道问题出在哪里。我的代码是:。main.c。sqlite.h。Sqlite.c。Confi
我正在尝试用带有c的sqlite3创建一个CGI可执行文件。但我收到错误exc_badd_access,我不知道问题出在哪里。我的代码是:。Main.c。sqlite.h。Sqlite.c。Confi
我正在尝试暂停 AVAudioPlayer如果当前正在播放。当我调试我的代码并检查时 AVAudioPlayer ,我看是分配的。当我尝试访问它的方法/属性(即 myAudioPlayer isPla
我正在使用 xcode 用 C 语言编写这个简单的程序。 #include int main() { double A[200][200][2][1][2][2]; int B[2
这是我得到的错误 Thread 1:EXC_BAD_ACCESS (code=2, address=0xb7ffffc) 在这条线上 [[NSNotificationCenter defaultCen
我的 iPhone 应用程序出现问题,出现 EXC_BAD_ACCESS,出现一些内存泄漏,但这些问题现已修复,所以我不确定发生了什么。我意识到我没有提供很多信息,但我真的不知道发生了什么。 打开初始
//adds a button to scroll list -(void) addNode:(NSString *) atitle{ UIButton *btn = [UIButton
我几乎完成了我的第一个应用程序,但我遇到了一个奇怪的 EXC_BAD_ACCESS,这种情况几乎一直在发生。 这是跟踪: #0 0x02adba93 in objc_msgSend #1 0x0702
我一直在研究核心数据,并开始编写一些方法来查询不同日期范围的数据。我的核心数据模型非常简单(名为 Smoke 的实体,具有一个字段 - 时间戳(日期类型)。 当我执行代码时,会返回正确的计数,但出现自
我有以下代码: ABAddressBookRef ab; ab = ABAddressBookCreate(); int len = (int) ABAddressBookGetPersonCount
希望有人可以帮助我调试这个问题,因为 EXC_BAD_ACCESS 是我收到的唯一错误。我也尝试过打开 NSZombieEnabled,但据我所知,没有获得更多信息。 问题。我有四个实体: A ->
我正在 tableView 上加载自定义单元格,并在 tableView 中返回 50 行。一些行数显示在表格 View 中,但是当滚动表格 View 时,我的自定义单元格不显示,并且出现错误 "EX
我正在尝试使用 NSLog 来打印控制台消息。问题是有时我在调用它时收到“EXC_BAD_ACCESS”错误 -(void)willRotateToInterfaceOrientation:(UIIn
这是我使用音频队列生成噪音的代码: http://pastebin.com/Kn8GU72J 问题是我的代码生成了 EXC_BAD_ACCESS。问题似乎出在作业中 MAAudioManage
我正在开发适用于 iOS 的 OpenGL ES 2 应用程序。今天早上(没有更改任何代码)我开始从 sgxTextureGetImageRowBytes 抛出 EXC_BAD_ACCESS。 #0
我在这里完全迷路了。 我的应用程序中有Google Analytics(分析),可查看有多少用户从UITableView进入detailview 我在viewDidLoad方法中添加了Google A
我是 Cocoa 新手,正在编写一个简单的应用程序来学习使用 Core Data,但它因 EXC_BAD_ACCESS 而崩溃。尝试了几种方法,但尚未找到解决方案。正如我所说,我对 Cocoa 的经验
以下代码使应用程序崩溃,我不知道为什么。它不规则地崩溃,这意味着有时单击一行时 ImageView 可以显示 30 次,有时当我选择一行时它会第二次崩溃。 仅供引用:事件指示器、操作表和变量 imag
我是一名优秀的程序员,十分优秀!