AVAudio, случайные сбои

Вот странная проблема со звуком в приложении для iOS.

Поскольку мой код работает примерно 90% времени, воспроизвести ошибку не так просто.

Но проблема, кажется, возникает (время от времени) в конце записи; или когда я прекращаю запись вручную или когда она останавливается автоматически.

Под отладчиком я вижу сбой в программе, связанный с подключением / отключением наушников. На самом деле наушники не подключены, и я не подключаю и не отключаю наушники вообще.

У меня есть этот код в какой-то момент в моей программе:

AudioSessionPropertyID routeChangeID=kAudioSessionProperty_AudioRouteChange;
AudioSessionAddPropertyListener(routeChangeID,svcHandleRouteChange,(__bridge void *)(self));

и это:

void svcHandleRouteChange(void *inUserData,AudioSessionPropertyID inPropertyID,
                          UInt32 inPropertyValueSize,const void *inPropertyValue)
{
    CFStringRef route;
    UInt32 propertySize=sizeof(CFStringRef);
    if (AudioSessionGetProperty(kAudioSessionProperty_AudioRoute,&propertySize,&route)==0)  {
        NSString *routeString = (__bridge NSString *) route;
        if ([routeString isEqualToString: @"Headphone"]) {
            // A headphone is now plugged in.
            // We do nothing.
        } else if ([routeString isEqualToString: @"Speaker"]) {
            // No headphone is plugged in. The device is using the speaker.
            LocalViewController* this=(__bridge LocalViewController*)inUserData;

            //[this->audioPlayer pause]; // The private variable audioPlayer could be accessed like this.
            [this headPhoneOut];
        } else {
            // This should not happen!!
        }
    }
}

Сбой происходит в строке: LocalViewController* this=(__bridge LocalViewController*)inUserData;

И, наконец, вот обратный след, который я получаю в отладчике после сбоя на случай, если кто-то может подсказать мне:

(lldb) bt
* thread #5: tid = 0x292d8, 0x3abba0ec libobjc.A.dylib`objc_retain + 12, stop reason = EXC_BAD_ACCESS (code=1, address=0x6e966a29)
    frame #0: 0x3abba0ec libobjc.A.dylib`objc_retain + 12
    frame #1: 0x000eb7d6 parl100`svcHandleRouteChange(inUserData=0x14e5f190, inPropertyID=1919902568, inPropertyValueSize=4, inPropertyValue=0x14f0b120) + 182 at LocalViewController.m:801
    frame #2: 0x301ae944 AudioToolbox`AudioSessionPropertyListeners::CallPropertyListenersImp(unsigned long, unsigned long, void const*) + 684
    frame #3: 0x301ae456 AudioToolbox`AudioSessionPropertyListeners::CallPropertyListeners(unsigned long, unsigned long, void const*) + 334
    frame #4: 0x301aee90 AudioToolbox`HandleCFPropertyListChange(unsigned int, unsigned long, unsigned char*, unsigned int) + 412
    frame #5: 0x301aec7e AudioToolbox`HandleAudioSessionPropertyChangedBlobListenerMessage(unsigned int, void*, unsigned int) + 206
    frame #6: 0x301aeb0e AudioToolbox`ASCallbackReceiver_AudioSessionPropertyChangedBlobListenerMessage + 178
    frame #7: 0x301aea3e AudioToolbox`_XAudioSessionPropertyChangedBlobListenerMessage + 94
    frame #8: 0x301ae088 AudioToolbox`mshMIGPerform + 124
    frame #9: 0x308dc9e6 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 34
    frame #10: 0x308dc982 CoreFoundation`__CFRunLoopDoSource1 + 346
    frame #11: 0x308db156 CoreFoundation`__CFRunLoopRun + 1398
    frame #12: 0x30845ce6 CoreFoundation`CFRunLoopRunSpecific + 522
    frame #13: 0x30845aca CoreFoundation`CFRunLoopRunInMode + 106
    frame #14: 0x2f837588 libAVFAudio.dylib`GenericRunLoopThread::Entry(void*) + 128
    frame #15: 0x2f82ba96 libAVFAudio.dylib`CAPThread::Entry(CAPThread*) + 178
    frame #16: 0x3b1e4c1c libsystem_pthread.dylib`_pthread_body + 140
    frame #17: 0x3b1e4b8e libsystem_pthread.dylib`_pthread_start + 102
(lldb) 

Вот второй случай, когда та же проблема возникает в другой точке приложения:

2013-10-23 12:25:12.135 parl100[1532:60b] audioRecorderDidFinishRecording
(lldb) bt
* thread #5: tid = 0x2b37a, 0x3abba0ec libobjc.A.dylib`objc_retain + 12, stop reason = EXC_BAD_ACCESS (code=1, address=0xd0003511)
    frame #0: 0x3abba0ec libobjc.A.dylib`objc_retain + 12
    frame #1: 0x000f18a2 parl100`cvcHandleRouteChange(inUserData=0x176b5610, inPropertyID=1919902568, inPropertyValueSize=4, inPropertyValue=0x1762d660) + 182 at ZapViewController.m:566
    frame #2: 0x301ae944 AudioToolbox`AudioSessionPropertyListeners::CallPropertyListenersImp(unsigned long, unsigned long, void const*) + 684
    frame #3: 0x301ae456 AudioToolbox`AudioSessionPropertyListeners::CallPropertyListeners(unsigned long, unsigned long, void const*) + 334
    frame #4: 0x301aee90 AudioToolbox`HandleCFPropertyListChange(unsigned int, unsigned long, unsigned char*, unsigned int) + 412
    frame #5: 0x301aec7e AudioToolbox`HandleAudioSessionPropertyChangedBlobListenerMessage(unsigned int, void*, unsigned int) + 206
    frame #6: 0x301aeb0e AudioToolbox`ASCallbackReceiver_AudioSessionPropertyChangedBlobListenerMessage + 178
    frame #7: 0x301aea3e AudioToolbox`_XAudioSessionPropertyChangedBlobListenerMessage + 94
    frame #8: 0x301ae088 AudioToolbox`mshMIGPerform + 124
    frame #9: 0x308dc9e6 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE1_PERFORM_FUNCTION__ + 34
    frame #10: 0x308dc982 CoreFoundation`__CFRunLoopDoSource1 + 346
    frame #11: 0x308db156 CoreFoundation`__CFRunLoopRun + 1398
    frame #12: 0x30845ce6 CoreFoundation`CFRunLoopRunSpecific + 522
    frame #13: 0x30845aca CoreFoundation`CFRunLoopRunInMode + 106
    frame #14: 0x2f837588 libAVFAudio.dylib`GenericRunLoopThread::Entry(void*) + 128
    frame #15: 0x2f82ba96 libAVFAudio.dylib`CAPThread::Entry(CAPThread*) + 178
    frame #16: 0x3b1e4c1c libsystem_pthread.dylib`_pthread_body + 140
    frame #17: 0x3b1e4b8e libsystem_pthread.dylib`_pthread_start + 102
(lldb) 

Я могу предоставить больше кода, если это необходимо. Просто скажи мне, что я должен включить.

Я надеюсь, что кто-то может указать мне на то, что я не должен делать правильно.

0 ответов

Другие вопросы по тегам