Подтвердить что ты не робот

Почему AudioServicesCreateSystemSoundID генерирует исключение внутри, но возвращает 0 как код ошибки?

Im запускает программу iOS в 4.3.2, 5.0 и 5.1 симуляторах, а Im наносит странное внутреннее исключение в AudioToolbox. У меня есть точка останова в Xcode (Xcode 4.3.1, работающая на 10.7.3) для всех исключений, и отладчик прерывается во время вызова AudioServicesCreateSystemSoundID():

SystemSoundID soundID;
OSStatus errorCode = AudioServicesCreateSystemSoundID(soundFileURLRef, &soundID);
                  // ^ boom. ^

Обратный ход:

(lldb) bt
* thread #1: tid = 0x1f03, 0x9000e230 libc++abi.dylib`__cxa_throw, stop reason = breakpoint 1.2
frame #0: 0x9000e230 libc++abi.dylib`__cxa_throw
frame #1: 0x00144193 AudioToolbox`ID3ParserHandle::ID3ParserHandle(void*, long (*)(void*, unsigned long, unsigned long, unsigned long, void**, unsigned long*)) + 259
frame #2: 0x001442de AudioToolbox`ID3ParserOpen + 62
frame #3: 0x0006c0e7 AudioToolbox`MPEGAudioFile::ParseID3Tags() + 87
frame #4: 0x0006c2ba AudioToolbox`MPEGAudioFile::ParseAudioFile() + 26
frame #5: 0x00015153 AudioToolbox`AudioFileOpenWithCallbacks + 371
frame #6: 0x00027020 AudioToolbox`_ZL15VerifyAndMapURLPK7__CFURLRx + 448
frame #7: 0x00026d85 AudioToolbox`_ZL18ActionDataToServerPK7__CFURLm + 933
frame #8: 0x000da26b AudioToolbox`AudioServicesCreateSystemSoundID + 235
frame #9: 0x00005be1 app`-[SoundsViewController playSoundForPath:] + 257 at SoundsViewController.m:161
frame #10: 0x00005a99 app`-[SoundsViewController tableView:didSelectRowAtIndexPath:] + 777 at SoundsViewController.m:129
frame #11: 0x0029db68 UIKit`-[UITableView _selectRowAtIndexPath:animated:scrollPosition:notifyDelegate:] + 1140
frame #12: 0x00293b05 UIKit`-[UITableView _userSelectRowAtPendingSelectionIndexPath:] + 219
frame #13: 0x009ad79e Foundation`__NSFireDelayedPerform + 441
frame #14: 0x00fb58c3 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 19
frame #15: 0x00fb6e74 CoreFoundation`__CFRunLoopDoTimer + 1220
frame #16: 0x00f132c9 CoreFoundation`__CFRunLoopRun + 1817
frame #17: 0x00f12840 CoreFoundation`CFRunLoopRunSpecific + 208
frame #18: 0x00f12761 CoreFoundation`CFRunLoopRunInMode + 97
frame #19: 0x01f6b1c4 GraphicsServices`GSEventRunModal + 217
frame #20: 0x01f6b289 GraphicsServices`GSEventRun + 115
frame #21: 0x00234c93 UIKit`UIApplicationMain + 1160
frame #22: 0x00002c45 app`main + 181 at main.m:14

Однако аудиофайл в soundID создается успешно, а код ошибки OSStatus, который AudioServicesCreateSystemSoundID возвращает, равен 0.

Это происходит во всех трех версиях iOS Simulator, которые я установил, и на моем iPhone работает 5.1.

Это похоже на ту же общую обратную трассировку, что и AVAudioPlayer выдает точку останова в режиме отладки, хотя мой результат является результатом более прямого вызова AudioToolbox.

Я хочу записать это с помощью Apple, так как его ошибка в AudioToolbox (фреймворки не должны использовать исключения для управления потоком, для каждого альбома и т.д.), но прежде чем я это сделаю, Im задается вопросом, какую дополнительную информацию я могу собрать, чтобы дать им, и если theres любой способ избежать этого броска (возможно, путем настройки тэгов ID3 ​​в этом mp3?)

4b9b3361

Ответ 1

Библиотеки С++ могут бросать исключения и исключать их изнутри по разным причинам, например, конец буфера или конец файла. Является ли это подходящим использованием исключений, хороший стиль кодирования или практика разработки программного обеспечения являются спорными. До тех пор, пока исключение не превратит его в ваш код, вы не должны беспокоиться об этом.

Вы говорите, что процедура возвращается успешно, и желаемый результат получается, поэтому ничего не получается (т.е. это не ошибка).

Ответ 2

Мы столкнулись с исключением в том же месте, оказалось, что mp3 файлы, которые он встречал, не имели действительных тегов ID3, запуская их через приложение, такое как Tagr зафиксировали их.