3

SoundPool.release() の呼び出し中に、次の ANR を取得しています。これは一貫した欠陥ではなく、ランダムに発生します。したがって、それを再現するにはちょっと時間がかかります。これを修正するには、AsyncTask または Thread の 2 つの方法があります。release は UIThread で実行されるべきではないため、ここで Handler を使用できるとは思いません。

DALVIK THREADS:
(mutexes: tll=0 tsl=0 tscl=0 ghl=0 hwl=0 hwll=0)
"main" prio=5 tid=1 NATIVE
  | group="main" sCount=1 dsCount=0 obj=0x400281b8 self=0xd088
  | sysTid=3623 nice=0 sched=0/0 cgrp=default handle=-1345006464
  | schedstat=( 22209377936 9072495824 21774 )
  at android.media.SoundPool.release(Native Method)

スレッドを使用して修正しました

public SoundManager() {
    releaseRunnable = new Runnable() {
        @Override
        public void run() {
            synchronized (releaseRunnable) {
                mSoundPool.release();
                mSoundPool = null;
            }
        }
    };
    releaseThread = new Thread(releaseRunnable);
}
public void release() {
    if (mSoundPool != null) {
        releaseThread.start();
    }
}

私はそれを正しくやっていますか?

4

0 に答える 0