1. 在MessageListActivity中出现异常:Receiver not registered.

07-16 11:15:47.881: E/AndroidRuntime(32361): FATAL EXCEPTION: main
07-16 11:15:47.881: E/AndroidRuntime(32361): java.lang.RuntimeException: Unable to destroy activity {com.txrj.sms/com.txrj.sms.activity.MessageListActivity}: java.lang.IllegalArgumentException: Receiver not registered: com.txrj.sms.activity.MessageListActivity$6@41dd73f0
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3129)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3147)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread.access$1200(ActivityThread.java:128)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1194)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.os.Looper.loop(Looper.java:137)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread.main(ActivityThread.java:4517)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at java.lang.reflect.Method.invokeNative(Native Method)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at java.lang.reflect.Method.invoke(Method.java:511)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:993)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:760)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at dalvik.system.NativeStart.main(Native Method)
07-16 11:15:47.881: E/AndroidRuntime(32361): Caused by: java.lang.IllegalArgumentException: Receiver not registered: com.txrj.sms.activity.MessageListActivity$6@41dd73f0
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.LoadedApk.forgetReceiverDispatcher(LoadedApk.java:628)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ContextImpl.unregisterReceiver(ContextImpl.java:1190)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.content.ContextWrapper.unregisterReceiver(ContextWrapper.java:361)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at com.txrj.sms.activity.MessageListActivity.onDestroy(MessageListActivity.java:327)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.Activity.performDestroy(Activity.java:4634)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1083)
07-16 11:15:47.881: E/AndroidRuntime(32361):     at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3116)
07-16 11:15:47.881: E/AndroidRuntime(32361):     ... 11 more

2. 查看BroadcastReceiver API文档,了解到广播的onReceive方法执行完,然后广播就不再处于active状态了。所以当发出信息成功之后,通过Toast.makeText弹出提示告知用户,然后onReceive方法结束,广播的生命周期就结束了。从中还了解到onReceive方法中可以执行Toast.makeText()表现了广播的onReceive方法是在主线程中执行的,否则就无法执行Toast.makeText方法了。

private void createAndRegisterDeliveryIntent() {
    deliveryReceiver = new BroadcastReceiver(){

        @Override
        public void onReceive(Context context, Intent intent) {
            mContext.unregisterReceiver(this);
           Toast.makeText(context, "message arrived.", Toast.LENGTH_SHORT).show();
        }
    };
    IntentFilter filter = new IntentFilter(TxrjConstant.ACTION_DELIVERY_SMS);
    mContext.registerReceiver(deliveryReceiver, filter);
}

3. 查看上面的代码片段红色部分。这条语句不应该出现。因为在Activity的onDestroy()方法中调用了注销方法。

Receiver not registered.的更多相关文章

  1. 错误:java.lang.IllegalArgumentException: Receiver not registered

    Caused by: java.lang.IllegalArgumentException: Receiver not registered: com.multak.cookaraclient.Mai ...

  2. Android高级之十二讲之如何降低应用内存消耗

    安卓应用的内存往往是有限的,从开始的8M到16M,24M,32M,48M,64M等逐步变大,但内存的变大是由于分辨率的提高导致,并不意味着可以随意声明使用内存,而不及时回收(即使Java有自己的垃圾回 ...

  3. android-webview开发中的各种使用方法(持续更,尽量全)

    最新坑A:(没看过的可以从下面开始处看起): 测试部门测出来一个坑,当多次点击退出后,会出现app崩溃现象,报如下错误: java.lang.IllegalArgumentException: Rec ...

  4. Android学习系列(37)--App调试内存泄露之Context篇(下)

    接着<Android学习系列(36)--App调试内存泄露之Context篇(上)>继续分析. 5. AsyncTask对象 我N年前去盛大面过一次试,当时面试官极力推荐我使用AsyncT ...

  5. [Android Memory] App调试内存泄露之Context篇(下)

    转载地址:http://www.cnblogs.com/qianxudetianxia/p/3655475.html 5. AsyncTask对象 我N年前去盛大面过一次试,当时面试官极力推荐我使用A ...

  6. android中broadcastreceiver的用法-代码中注册

    界面如下:     问题1:点击“解绑广播接收器“后再次点击”解绑广播接收器“后,程序崩溃,log信息如下: 08-04 05:04:35.420: E/AndroidRuntime(5521): F ...

  7. 广播接收者 BroadcastReceiver 示例-1

    广播机制概述 Android广播分为两个方面:广播发送者和广播接收者,通常情况下,BroadcastReceiver指的就是广播接收者.广播作为Android组件间的通信方式,可以使用的场景如下: 1 ...

  8. django之signal机制再探

    djangobb中的signal post_save信号调用send函数时,为什么它会对与topic.post相关的其他models进行修改?同一个信号,例如post_save(保存过后的处理),是所 ...

  9. BroadcastReceiver 翻译

    1. 动态注册与退出 If registering a receiver in your Activity.onResume() implementation, you should unregist ...

随机推荐

  1. how to fix bug in daily work

    0 QE will begin test the product when system is stable. so they may log a lot of issues, and our dai ...

  2. [leetcode]Substring with Concatenation of All Words @ Python

    原题地址:https://oj.leetcode.com/problems/substring-with-concatenation-of-all-words/ 题意: You are given a ...

  3. 什么是L2 frame?

    The data link layer or layer 2 is the second layer of the seven-layer OSI model of computer networki ...

  4. Java去掉Html标签的方法

    content = content.replaceAll("\\&[a-zA-Z]{1,10};", "").replaceAll("< ...

  5. Laravel应用性能调优

    这次性能测试方案中用到的优化技巧主要基于 Laravel 框架本身及其提供的工具. 关闭应用debugapp.debug=false 缓存配置信息php artisan config:cache 缓存 ...

  6. 使用 GNU Libtool 创建库

    这篇文档向大家介绍 GNU Libtool 的用途及基本使用方法,同时描述如何结合 GNU Autoconf 和 Automake 来使用 Libtool. 3 评论: 吴 小虎, 程序员, 天用唯勤 ...

  7. Mysql 使用Group 和Case When统计数据

    项目是基于:thinkcmf的,新的需求是对各栏目的文章数量进行统计 SQl很简单,先根据分类ID进行分组,然后再通过CASE WHEN 再统计不同文章状态数量 ) as count , =已审核 , ...

  8. Mysql正则匹配某列是否含有手机号

    SELECT COUNT(1) FROM t_user WHERE user_name REGEXP ".[1][35678][0-9]{9}."; 解释: 正则中 .的意思是所有 ...

  9. 关于Spring mvc 一次请求Controller执行两次的问题

    资源路径为空时也会导致重复请求.< span style="background-image:url('');" >相关推荐< /span >,此时就会出现 ...

  10. 在linux 中wget 无法解析主机

    vim /etc/resolv.cof 在里面加入节点 nameserver 8.8.8.8 / nameserver 8.8.4.4 即可 失败时: 成功时: