Android音频服务泄漏了服务连接

Android音频服务泄漏了服务连接,android,logcat,android-audiomanager,Android,Logcat,Android Audiomanager,我正在开发音乐播放器的应用程序。 我正面临着这样的错误 “*.MusicLayerTabWidget已泄漏ServiceConnection* 请对此发表评论。 我也为此分享我的日志 05-01 10:38:03.226: W/KeyCharacterMap(4225): Using default keymap 05-01 10:38:03.429: E/ActivityThread(4225): Activity com.pvMusic.pvm.MusicPlayerTabWidget ha

我正在开发音乐播放器的应用程序。 我正面临着这样的错误

“*.MusicLayerTabWidget已泄漏ServiceConnection*

请对此发表评论。 我也为此分享我的日志

05-01 10:38:03.226: W/KeyCharacterMap(4225): Using default keymap
05-01 10:38:03.429: E/ActivityThread(4225): Activity com.pvMusic.pvm.MusicPlayerTabWidget has leaked ServiceConnection com.pvMusic.pvm.MusicPlayerTabWidget$1@4051c6f0 that was originally bound here
05-01 10:38:03.429: E/ActivityThread(4225): android.app.ServiceConnectionLeaked: Activity com.pvMusic.pvm.MusicPlayerTabWidget has leaked ServiceConnection com.pvMusic.pvm.MusicPlayerTabWidget$1@4051c6f0 that was originally bound here
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.LoadedApk$ServiceDispatcher.<init>(LoadedApk.java:938)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:833)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ContextImpl.bindService(ContextImpl.java:879)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.content.ContextWrapper.bindService(ContextWrapper.java:347)
05-01 10:38:03.429: E/ActivityThread(4225):     at com.pvMusic.pvm.MusicPlayerTabWidget.onStart(MusicPlayerTabWidget.java:175)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1129)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.Activity.performStart(Activity.java:3791)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1624)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.os.Handler.dispatchMessage(Handler.java:99)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.os.Looper.loop(Looper.java:130)
05-01 10:38:03.429: E/ActivityThread(4225):     at android.app.ActivityThread.main(ActivityThread.java:3687)
05-01 10:38:03.429: E/ActivityThread(4225):     at java.lang.reflect.Method.invokeNative(Native Method)
05-01 10:38:03.429: E/ActivityThread(4225):     at java.lang.reflect.Method.invoke(Method.java:507)
05-01 10:38:03.429: E/ActivityThread(4225):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
05-01 10:38:03.429: E/ActivityThread(4225):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
05-01 10:38:03.429: E/ActivityThread(4225):     at dalvik.system.NativeStart.main(Native Method)
05-01 10:39:31.859: D/dalvikvm(4225): GC_EXPLICIT freed 166K, 46% free 3022K/5575K, external 557K/1031K, paused 52ms
05-01 10:39:31.906: D/dalvikvm(4225): GC_CONCURRENT freed 0K, 46% free 3022K/5575K, external 557K/1031K, paused 4ms+3ms
05-01 10:38:03.226:W/KeyCharacterMap(4225):使用默认的keymap
05-01 10:38:03.429:E/ActivityThread(4225):Activity com.pvMusic.pvm.MusicPlayerTabWidget已泄漏服务连接com.pvMusic.pvm.MusicPlayerTabWidget$1@4051c6f0原来是订在这里的
05-01 10:38:03.429:E/ActivityThread(4225):android.app.ServiceConnectionLeaked:Activity com.pvMusic.pvm.MusicPlayerTabWidget已泄漏ServiceConnection com.pvMusic.pvm.MusicPlayerTabWidget$1@4051c6f0原来是订在这里的
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.LoadedApk$ServiceDispatcher(LoadedApk.java:938)
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.LoadedApk.getServiceDispatcher(LoadedApk.java:833)
05-01 10:38:03.429:E/ActivityThread(4225):位于android.app.ContextImpl.bindService(ContextImpl.java:879)
05-01 10:38:03.429:E/ActivityThread(4225):位于android.content.ContextWrapper.bindService(ContextWrapper.java:347)
05-01 10:38:03.429:E/ActivityThread(4225):在com.pvMusic.pvm.MusicPlayerTabWidget.onStart(MusicPlayerTabWidget.java:175)上
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1129)上
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.Activity.performStart(Activity.java:3791)上
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1624)
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.ActivityThread.access$1500(ActivityThread.java:117)
05-01 10:38:03.429:E/ActivityThread(4225):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
05-01 10:38:03.429:E/ActivityThread(4225):位于android.os.Handler.dispatchMessage(Handler.java:99)
05-01 10:38:03.429:E/ActivityThread(4225):位于android.os.Looper.loop(Looper.java:130)
05-01 10:38:03.429:E/ActivityThread(4225):位于android.app.ActivityThread.main(ActivityThread.java:3687)
05-01 10:38:03.429:E/ActivityThread(4225):位于java.lang.reflect.Method.Invokenactive(本机方法)
05-01 10:38:03.429:E/ActivityThread(4225):位于java.lang.reflect.Method.invoke(Method.java:507)
05-01 10:38:03.429:E/ActivityThread(4225):位于com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
05-01 10:38:03.429:E/ActivityThread(4225):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
05-01 10:38:03.429:E/ActivityThread(4225):在dalvik.system.NativeStart.main(本机方法)
5-01 10:39:31.859:D/dalvikvm(4225):GC_显式释放166K,46%释放3022K/5575K,外部557K/1031K,暂停52ms
5-01 10:39:31.906:D/dalvikvm(4225):GC_并发释放0K,46%释放3022K/5575K,外部557K/1031K,暂停4ms+3ms

更多信息,如果您有任何有关音乐播放器的参考教程,请与我共享。

退出活动后,您试图显示一些内容(您的线程返回)。

如果您在活动中对服务进行本地绑定,您需要确保在活动结束时断开与服务的连接。否则,应用程序将开始泄漏连接,如您的错误所示。

如图所示,您应该覆盖
onDestroy
,并关闭活动关闭后正在运行的对话框。

添加
解除绑定服务(mConnection)onstop()方法中的code>。代码将开始正常工作。

当您的服务已注册BroadcastReceiver而未注销时,也会发生这种情况

所以请在onDestroy中注销它

    unregisterReceiver(mReceiver);

如果改为绑定到getApplicationContext(),则只要应用程序正在运行,绑定就会一直运行。如果您绑定到getContext(),并且活动的上下文被破坏,android会注意到您没有关闭与该上下文相关的连接。

您能更好地解释一下吗?不知道该放在哪里it@StefanoMunarini阅读Android生命周期!(在本例中为活动生命周期)我知道这是一个老问题,但我需要帮助!如果需要在后台android服务中运行服务,我们不能“调用”bindService(新意图(IRecordService.class.getName()),mServiceConnection,Context.BIND_AUTO_CREATE);“?”??如果我想在挂起的意图通知中保持服务的活动性,我必须做什么?示例:-我单击了录制音频的活动,并通知“录制”,如果单击“上一步”按钮,如果调用“取消绑定服务”,它将停止录制!!我想我是否必须将“活动内部服务的本地绑定”更改为startService