昨天测试跑monkey跑出了一个异常,bug发给我之后,先看了一下异常信息,如下:
java.lang.SecurityException: Permission Denial: not allowed to send broadcast android.intent.action.BATTERY_CHANGED from pid=26154, uid=10080 at android.os.Parcel.readException(Parcel.java:1546) at android.os.Parcel.readException(Parcel.java:1499) at android.app.ActivityManagerProxy.broadcastIntent(ActivityManagerNative.java:2872) at android.app.ContextImpl.sendBroadcast(ContextImpl.java:1366) at android.content.ContextWrapper.sendBroadcast(ContextWrapper.java:377) at com.bbk.recorder.MainActivity$BatteryLevelReceiver.onReceive(MainActivity.java:1136) at android.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:866) at android.os.Handler.handleCallback(Handler.java:739) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:135) at android.app.ActivityThread.main(ActivityThread.java:5291) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:969) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:764)
初步分析发现是因为电量变化的广播属于系统广播,非系统应用无权限发送这个广播,为什么会这样呢?细看自己的代码发现:
class BatteryLevelReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { if (getBatteryLevel() > 0.05) { return; } else { Intent intent1 = new Intent(ACTION_BACKGROUND_RECORD_STATE); intent1.putExtra("key_recording_content",mContentTitle); intent1.putExtra("key_recording_flag",true); MainActivity.this.sendBroadcast(intent); } }}在我注册的电量变化广播接收器中,有发送广播的行为,本意是向桌面状态栏发送时间变化的广播 intent1,没想到由于命名的原因,写成了 intent,少写了一个1,intent1是我要发的广播,intent是广播接收器的入参之一,也就是电量变化的intent,这个intent是不允许随便发的;这其实就是个手误,写错了参数,谨以此为戒!
以上只是我解决问题过程中的一点点个人总结,点滴积累,贵在坚持,感谢你的阅览!
