Android开发错误记录:MainActivity (server)' ~ Channel is unrecoverably broken and will be disposed!

今天遇到了一个头疼的问题,就是本来程序昨天都是好好的,但是今天在该页面退出的时候就报通道破碎错误了,直接闪屏,头大,上网搜了一下资料,再结合昨晚写的代码,预估可能是网络请求的问题,搞了半天解决了,记录一下。

报错记录

    05-25 10:52:21.125 491-528/system_process E/InputDispatcher: channel '4a8b59f4 activity.MainActivity (server)' ~ Channel is unrecoverably broken and will be disposed!
    05-25 10:52:21.125 491-528/system_process E/InputDispatcher: channel '4a9790c4 activity.ShoppingCartActivity (server)' ~ Channel is unrecoverably broken and will be disposed!

出错位置

private Handler mHandler = new Handler(){
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            switch (msg.what){
                case KEY:
                    if (ispay) {
                        Map<String, String> param = new HashMap<>();
                        String orderId = SharePreferenceUtils.readString(PayActivity.this, "user", "orderId");
                        param.put("orderId",orderId);
                        PayActivity.this.post(Api.PayResult,param, PayResultBean.class);
                    }
                    break;
                default:
                    break;
            }
        }
    };

这行网络请求(这是我写的一个xutils封装类里的post请求方法)出了问题:

PayActivity.this.post(Api.PayResult,param, PayResultBean.class);

具体原因就是因为页面在退出的时候,该行代码依然在执行,所以报错,紧急之下也没做其他的处理,只是写了一个标志位,在页面退出的时候设置为false,这个方法其实不太好,暂时先这样,后期改进。

@Override
    protected void onDestroy() {
        super.onDestroy();
        ispay = false;
    }

解决问题思路

改正后,就不在报那个错了,从报这个错误消息的情况来看,如果程序报Channel is unrecoverably broken and will be disposed!时,首先可以考虑是不是代码中某个有数据输入或是有数据输出的地方,写错了代码。

稍做补充

下午又遇到这个问题了,看了一下,原来是后台接口数据做了改动,我重新生成bean对象的时候,有个为long类型的数据变成了String类型我也没注意到,改正过来就好了。写代码细心很重要,引以为戒,下不为例。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值