android - WARN/AudioFlinger(33) : write blocked for 76 msecs, 7773 延迟写入,线程 0xb3f0

标签 android android-mediaplayer

我已经创建了一个 Intent 服务来在后台启动我的应用程序的音乐。

它正在工作,但我的 log-cat 充满了消息:

09-14 16:46:30.117:WARN/AudioFlinger(33):写入阻塞 76 毫秒,7773 次延迟写入,线程 0xb3f0 并且没有其他任何内容被记录。

这是我的 IntentService:

import android.app.IntentService;
import android.content.Intent;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnErrorListener;
import android.widget.Toast;

public class MusicService extends IntentService {

    MediaPlayer mPlayer;
    private OnErrorListener mErrorListener;

    public MusicService() {
        super("MusicService");
        // TODO Auto-generated constructor stub
    }

    @Override
    protected void onHandleIntent(Intent intent) {
        // TODO Auto-generated method stub
          // Normally we would do some work here, like download a file.


    }   

    ///////////////////////////////////////////////////////////

    @Override
    public int onStartCommand (Intent intent, int flags, int startId)

    {
        Toast.makeText(this, "service starting", Toast.LENGTH_SHORT).show();
        mPlayer.setLooping(true);
        mPlayer.start();

        return super.onStartCommand(intent,flags,startId);


    }

    @Override

    public void onCreate ()

    {
        super.onCreate();
      //  try{
            mPlayer = MediaPlayer.create(this, R.raw.jingle);
        //}catch (IllegalArgumentException e) {
            //e.printStackTrace();
        //}catch (IllegalStateException e ) {
            //e.printStackTrace();
        //}

        if(mPlayer!= null)
        {
            mPlayer.setLooping(true); // Set looping
            mPlayer.setVolume(100,100);
        }


    mPlayer.setOnErrorListener(new OnErrorListener() {

        public boolean onError(MediaPlayer mp, int what, int extra) {
            // TODO Auto-generated method stub
            onPlayError();
            return true;
        }

    });


    }

    private void onPlayError() {
        Toast.makeText(this, "music player failed", Toast.LENGTH_SHORT).show(); 
        if(mPlayer != null)
        {
            try{
                mPlayer.stop();
                mPlayer.release();
            }finally {
                mPlayer = null;
            }
        }
    }

最佳答案

需要权限。将这些放在 AndroidManifest.xml 中:

<uses-sdk android:minSdkVersion="8" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />

我在android emulator 2.2下测试过所以我的minSdkVersion是8.

关于android - WARN/AudioFlinger(33) : write blocked for 76 msecs, 7773 延迟写入,线程 0xb3f0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7422374/

相关文章:

java - 如何在 Exoplayer android 中向视频添加字幕(.SRT 文件)?

android - 调整九片PNG的中心

java - PowerMockito 给出 NoClassDefFoundError

android - 当方向改变时, Activity 恢复了两次

android - 如何让动画与 Android 中的 TextToSpeech 话语同时播放

android - 如何通过其uri播放音乐

java - android - 使用 VideoView 的多个实例时出错

android - MediaPlayer 没有被发布就完成了

android - MediaController 不在 ViewPager 中滑动

android - 谷歌地图中从源到目的地的路径可见性