【问题标题】:Battery changed broadcast receiver crashing app on some phones电池更换广播接收器在某些手机上崩溃的应用程序
【发布时间】:2013-02-27 09:15:55
【问题描述】:

只要手机接通电源,我就会激活我的应用程序。 这是我的清单

<receiver android:name=".PowerConnectionReceiver">
      <intent-filter>
        <action android:name="android.intent.action.ACTION_POWER_CONNECTED"/>
        <action android:name="android.intent.action.ACTION_POWER_DISCONNECTED"/>
      </intent-filter>
    </receiver>

这是我的广播接收器

  @Override
    public void onReceive(Context context, Intent intent) {
        Log.w("TAG", "Just received connection broadcast");


        IntentFilter ifilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
        Intent batteryStatus = context.registerReceiver(null, ifilter); //this line is causing the crash


        int status = batteryStatus.getIntExtra(BatteryManager.EXTRA_STATUS, 0);

现在,导致我朋友手机(我的一切正常)崩溃的线路是这条

Intent batteryStatus = context.registerReceiver(null, ifilter);

谁能告诉我是什么原因以及如何解决? 我的手机是带有最新 android JB 的 Galaxy nexus,他的手机是带有姜饼的 LG 擎天柱

这里是日志

    02-27 01:25:19.399: D/AndroidRuntime(5326): Shutting down VM
02-27 01:25:19.399: W/dalvikvm(5326): threadid=1: thread exiting with uncaught exception (group=0x40018560)
02-27 01:25:19.419: E/AndroidRuntime(5326): FATAL EXCEPTION: main
02-27 01:25:19.419: E/AndroidRuntime(5326): java.lang.RuntimeException: Unable to start receiver com.doublep.wakey.PowerConnectionReceiver: android.content.ReceiverCallNotAllowedException: IntentReceiver components are not allowed to register to receive intents
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ActivityThread.handleReceiver(ActivityThread.java:1926)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ActivityThread.access$2400(ActivityThread.java:123)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:989)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.os.Handler.dispatchMessage(Handler.java:99)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.os.Looper.loop(Looper.java:130)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ActivityThread.main(ActivityThread.java:3835)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at java.lang.reflect.Method.invokeNative(Native Method)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at java.lang.reflect.Method.invoke(Method.java:507)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:864)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:622)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at dalvik.system.NativeStart.main(Native Method)
02-27 01:25:19.419: E/AndroidRuntime(5326): Caused by: android.content.ReceiverCallNotAllowedException: IntentReceiver components are not allowed to register to receive intents
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ReceiverRestrictedContext.registerReceiver(ContextImpl.java:151)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ReceiverRestrictedContext.registerReceiver(ContextImpl.java:145)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at com.doublep.wakey.PowerConnectionReceiver.onReceive(PowerConnectionReceiver.java:46)
02-27 01:25:19.419: E/AndroidRuntime(5326):     at android.app.ActivityThread.handleReceiver(ActivityThread.java:1915)
02-27 01:25:19.419: E/AndroidRuntime(5326):     ... 10 more

【问题讨论】:

标签: android


【解决方案1】:

您将收到ReceiverCallNotAllowedException

这个异常是从registerReceiver(BroadcastReceiver, IntentFilter)bindService(Intent, ServiceConnection, int)抛出的,当 这些方法是从 BroadcastReceiver 组件中使用的。在 在这种情况下,组件在从返回时将不再处于活动状态 接收 Intent,因此使用异步 API 无效。

这意味着,您不能在BroadcastReceiver inside 注册BroadcastReceiver

编辑: 监听ACTION_BATTERY_CHANGED Intent 的 BroadcastReceiver 的工作示例:

    private int mBatteryLevel;
    private IntentFilter mBatteryLevelFilter;

    BroadcastReceiver mBatteryReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            mBatteryLevel = intent.getIntExtra(BatteryManager.EXTRA_LEVEL, -1);
            Toast.makeText(context, "Current Battery Level: " + mBatteryLevel, Toast.LENGTH_LONG).show();
        }
    };

    private void registerMyReceiver() {
        mBatteryLevelFilter = new IntentFilter(Intent.ACTION_BATTERY_CHANGED);
        registerReceiver(mBatteryReceiver, mBatteryLevelFilter);
    }

现在您只需致电registerMyReceiver()

【讨论】:

  • 谢谢,您能告诉我如何从广播接收器中检索电池状态(是否正在充电)?从意图获取电池状态让我总是不充电
  • @Ahmad 你展示的代码是一个java类吗?你在哪里调用方法 registerMyReceiver() ?在同一范围内,我不知道如何在 Manifiest 中声明它。非常感谢,所以可以以实用的方式学习它。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2023-04-05
  • 2021-07-26
  • 1970-01-01
  • 2012-12-12
  • 2013-11-26
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多