Receiver not registered.
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.的更多相关文章
- 错误:java.lang.IllegalArgumentException: Receiver not registered
Caused by: java.lang.IllegalArgumentException: Receiver not registered: com.multak.cookaraclient.Mai ...
- Android高级之十二讲之如何降低应用内存消耗
安卓应用的内存往往是有限的,从开始的8M到16M,24M,32M,48M,64M等逐步变大,但内存的变大是由于分辨率的提高导致,并不意味着可以随意声明使用内存,而不及时回收(即使Java有自己的垃圾回 ...
- android-webview开发中的各种使用方法(持续更,尽量全)
最新坑A:(没看过的可以从下面开始处看起): 测试部门测出来一个坑,当多次点击退出后,会出现app崩溃现象,报如下错误: java.lang.IllegalArgumentException: Rec ...
- Android学习系列(37)--App调试内存泄露之Context篇(下)
接着<Android学习系列(36)--App调试内存泄露之Context篇(上)>继续分析. 5. AsyncTask对象 我N年前去盛大面过一次试,当时面试官极力推荐我使用AsyncT ...
- [Android Memory] App调试内存泄露之Context篇(下)
转载地址:http://www.cnblogs.com/qianxudetianxia/p/3655475.html 5. AsyncTask对象 我N年前去盛大面过一次试,当时面试官极力推荐我使用A ...
- android中broadcastreceiver的用法-代码中注册
界面如下: 问题1:点击“解绑广播接收器“后再次点击”解绑广播接收器“后,程序崩溃,log信息如下: 08-04 05:04:35.420: E/AndroidRuntime(5521): F ...
- 广播接收者 BroadcastReceiver 示例-1
广播机制概述 Android广播分为两个方面:广播发送者和广播接收者,通常情况下,BroadcastReceiver指的就是广播接收者.广播作为Android组件间的通信方式,可以使用的场景如下: 1 ...
- django之signal机制再探
djangobb中的signal post_save信号调用send函数时,为什么它会对与topic.post相关的其他models进行修改?同一个信号,例如post_save(保存过后的处理),是所 ...
- BroadcastReceiver 翻译
1. 动态注册与退出 If registering a receiver in your Activity.onResume() implementation, you should unregist ...
随机推荐
- jboss中控制台jmx-console 登录的用户名和密码设置
默认情况访问 http://localhost:8080/jmx-console 就可以浏览jboss的部署管理的一些信息,不需要输入用户名和密码,使用起来有点安全隐患.下面我们针对此问题对jboss ...
- 6.1 如何在spring中自定义xml标签
dubbo自定义了很多xml标签,例如<dubbo:application>,那么这些自定义标签是怎么与spring结合起来的呢?我们先看一个简单的例子. 一 编写模型类 package ...
- Asp.net WebAPI Ioc
网上关于webapi Ioc 的东西很多,如http://efmvc.codeplex.com/SourceControl/latest#MyFinance.Web/Global.asax.cs 这是 ...
- [leetcode]Candy @ Python
原题地址:https://oj.leetcode.com/problems/candy/ 题意: There are N children standing in a line. Each child ...
- JPA(五):映射关联关系------映射单向多对一的关联关系
映射单向多对一的关联关系 新建Customer.java: package com.dx.jpa.singlemanytoone; import java.util.Date; import java ...
- lvs 隧道模式请求没有回应的解决
众所周知,lvs共有三种转发机制:NAT,IPTUNNELING与DIRECT ROUTING 我在做隧道模式实验时遇到了一个问题,客户端向虚拟ip(即隧道0的ip)发送请求后,lvs服务器接收到了请 ...
- python 导出mongoDB数据中的数据
import pymongo,urllibimport sysimport timeimport datetimereload(sys)sys.setdefaultencoding('utf8')fr ...
- 1418 This function has none of DETERMINISTIC,NO SQL,or R
标签: [err]1418 函数创建报错 分类: 菜鸟DBA之MySQL --------------------------------------------------------------- ...
- MySQL 存储过程/游标/事务
将会用到的几个表 mysql> DESC products; +------------+--------------+------+-----+---------+-------------- ...
- VO、DTO与领域模型的概念
业务对象模型(也叫领域模型 domain model)是描述业务用例实现的对象模型.它是对业务角色和业务实体之间应该如何联系和协作以执行业务的一种抽象.业务对象模型从业务角色内部的观点定义了业务用例. ...