Skip to content

FATAL EXCEPTION: AudioToWebSocketThread #94

@ZY6666

Description

@ZY6666

Sorry for my poor English, I will make it simple
I successfully ran the example,But when I set inactivityTimeout to 1 second, I want to automatically end the connection or catch error code, but the application crashes
heres the code:

private RecognizeOptions getRecognizeOptions(InputStream captureStream) {
    return new RecognizeOptions.Builder()
            .audio(captureStream)
            .contentType(ContentType.OPUS.toString())
            .model("ja-JP_BroadbandModel")
            .interimResults(true)
            .inactivityTimeout(1)
            .build();
  }

and crash log:

E/AndroidRuntime: FATAL EXCEPTION: AudioToWebSocketThread
    Process: com.ibm.watson.developer_cloud.android.myapplication, PID: 3228
    java.lang.IllegalMonitorStateException
        at java.util.concurrent.locks.ReentrantLock$Sync.tryRelease(ReentrantLock.java:156)
        at java.util.concurrent.locks.AbstractQueuedSynchronizer.release(AbstractQueuedSynchronizer.java:1291)
        at java.util.concurrent.locks.ReentrantLock.unlock(ReentrantLock.java:466)
        at com.ibm.watson.developer_cloud.android.library.audio.MicrophoneCaptureThread.end(MicrophoneCaptureThread.java:138)
        at com.ibm.watson.developer_cloud.android.library.audio.MicrophoneInputStream.close(MicrophoneInputStream.java:109)
        at com.ibm.watson.speech_to_text.v1.websocket.SpeechToTextWebSocketListener.sendInputStream(SpeechToTextWebSocketListener.java:213)
        at com.ibm.watson.speech_to_text.v1.websocket.SpeechToTextWebSocketListener.access$100(SpeechToTextWebSocketListener.java:42)
        at com.ibm.watson.speech_to_text.v1.websocket.SpeechToTextWebSocketListener$1.run(SpeechToTextWebSocketListener.java:168)

Crash code:
MicrophoneCaptureThread

public void end() {
    stop = true;

    if (!stopped) {
      try {
        running.tryLock(10, TimeUnit.SECONDS);
      } catch (InterruptedException e) {
        Log.e(TAG, e.getMessage());
      } finally {
        running.unlock();
      }
    }
  }

MicrophoneInputStream

@Override
  public void close() throws IOException {
    captureThread.end();
    os.close();
    is.close();
  }

Please help me,thank you very much

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions