android process is bad,Prevent Android “process is bad” error

问题

The process is bad error does not seem to be very well documented, and I have only been able to find workarounds. I am instead interested in the cause of this error and how to prevent it from happening, and not how to manually handle it through rebooting, relaunching app, etc.

My particular application uses an AlarmManager to launch an IntentService which runs for ~10s every ~30s. This is called on creation of the application:

Intent serviceIntent = new Intent(appContext, MyService.class);

serviceIntent.putExtra("service_extra", extra);

launchService = PendingIntent.getService(

appContext,

LAUNCH_SERVICE_REQUEST_CODE,

scanIntent,

PendingIntent.FLAG_UPDATE_CURRENT

);

alarmManager.setInexactRepeating(

AlarmManager.RTC,

System.currentTimeMillis() + interval,

interval,

launchService

);

This works as expected most of the time. However, very occasionally the service will fail to launch for an indefinite period, sometimes hours at a time. The following error is seen every ~30s, so I know my alarms are attempting to launch the IntentService as scheduled, but the attempt fails with a process is bad error.

Unable to launch app com.example.android/10024 for service Intent { cmp=com.example.android/.MyService (has extras) }: process is bad

This is fixed by simply reopening the app. But I need to know how to prevent it! The purpose of this service is to run in the background while activities are stopped or destroyed, so it must prevent this error without any user interaction or workaround.

回答1:

Good Chance is that it has to do with the handling of the activity's lifecycle.

It reminds me of a case I recently solved without fully understanding it because the documentation is not very specific on what you can rely on after onStop() is called on your Activity. And what exactly you shouldn't do...

So I can only give you some hints:

If my guess is right, you have problem with not being properly restored, when your App is (partially) removed from memory.

Try setting the limit for background-Apps in the developer-settings to "none".

I suspect that with this setting your problem will be completly reproducable when puting it to background. Otherwise you probably can stop reading here.

I had a thread that kept on running after onStop() that also kept some references. Stopping the thread in onPause() and also waiting for it to finsh solved my problem. I also needed to sync my onStop() because blocking onPause() resulted in onStop() coming in paralell. I also needed to move some of my initilization from onCreate() to onResume(). But that was quite obvious once I figured out at what to tear down in onResume() and onStop().

Probably the tipp with the static goes in the same direction.

回答2:

The "process is bad" error happens after your service crashes a couple times. The system prevents it from coming back up and instead prints that message. You can clear the crash count by rebooting or more quickly by killing the system server:

adb shell killall system_server

This is effectively a "soft reboot" and will kill/restart any processes you've got going.

来源:https://stackoverflow.com/questions/26452317/prevent-android-process-is-bad-error

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值