AndroidRuntime: FATAL EXCEPTION: FinalizerWatchdogDaemon问题解决

MainActivity有一个按钮,点按钮进入到CameraActivity,获取结果图片后返回MainActivity,然后联网发送结果图片并返回json结果。第一次点按钮进入CameraActivity并返回MainActivity结果的时候正常,第二次点按钮进入CameraActivity返回结果,一切正常,然后在MainActivity界面不动,等过了30秒(华为手机30秒,小米手机10秒)程序崩溃(如果第二次返回结果后30秒或10秒内继续点按钮进入CameraActivity程序正常)。查看日志log如下:

 E/AndroidRuntime: FATAL EXCEPTION: FinalizerWatchdogDaemon
     Process: com.example.test, PID: 6754
     java.util.concurrent.TimeoutException: org.apache.http.impl.conn.SingleClientConnManager.finalize() timed out after 30 seconds
     at libcore.io.Posix.close(Native Method)
     at libcore.io.BlockGuardOs.close(BlockGuardOs.java:101)
     at libcore.io.IoBridge.closeAndSignalBlockedThreads(IoBridge.java:203)
     at java.net.PlainSocketImpl.close(PlainSocketImpl.java:148)
     at java.net.Socket.close(Socket.java:366)
     at org.apache.http.impl.SocketHttpClientConnection.shutdown(SocketHttpClientConnection.java:188)
     at org.apache.http.impl.conn.DefaultClientConnection.shutdown(DefaultClientConnection.java:155)
     at org.apache.http.impl.conn.SingleClientConnManager$PoolEntry.shutdown(SingleClientConnManager.java:445)
     at org.apache.http.impl.conn.SingleClientConnManager.shutdown(SingleClientConnManager.java:381)
     at org.apache.http.impl.conn.SingleClientConnManager.finalize(SingleClientConnManager.java:140)
     at java.lang.Daemons$FinalizerDaemon.doFinalize(Daemons.java:202)
     at java.lang.Daemons$FinalizerDaemon.run(Daemons.java:185)
     at java.lang.Thread.run(Thread.java:833)
 I/Process: Sending signal. PID: 6754 SIG: 9

        查看日志,Watchdog,TimeoutException连接超时,跟Watchdog有关。查看资料,有人说这个问题避免不了,只能降低发生频率。但是我这是次次发生啊,必须解决。刚开始想不明白怎么出现的这个问题,查FinalizerWatchdogDaemon讲的都是底层原理,而没有解决方法。网上这个回复较多How to handle :java.util.concurrent.TimeoutException: android.os.BinderProxy.finalize() timed out after 10 seconds errors?,但是没明白什么意思、怎么处理。

        后来想到既然是TimeoutException,那应该跟联网有关吧。我们这个联网模块是之前别人写的,我接过来了,一直用,没有改过。之前没有出现这次这样的问题,后来因为程序有其他问题,就改代码改代码,到后来就出现这个问题了。看了些联网代码,是别人封装好的类,然后调用了。我就把之前的联网调用代码注释掉,用了OKhttp的联网框架。代码如下:

app下的build.gradle:

compile 'com.zhy:okhttputils:2.6.2'
compile 'com.squareup.okhttp3:okhttp:3.8.0'
compile 'com.squareup.okio:okio:1.5.0'

private void sendIDImg() {//上传本地图片到后台
        Map<String, String> params = new HashMap<>();
        params.put("api_key", apiKey);//API参数
        params.put("api_secret", apiSecret);
        params.put("attributes", "false");
        OkHttpUtils.post()
                .addFile("img_file","idcardp.jpg",FILE1)//本地图片
                .url(apiUrlDetect)//后台地址
                .params(params)
                .build()
                .execute(new MyStringCallback() {

                });
    }


public class MyStringCallback extends StringCallback {
        @Override
        public void onBefore(Request request, int id) {
        }

        @Override
        public void onAfter(int id) {
        }

        @Override
        public void onError(Call call, Exception e, int id) {
            e.printStackTrace();
            Log.e("onError:", e.getMessage());
        }

        @Override
        public void onResponse(String response, int id) {
            Log.e("onResponse", response);//response后台返回的json字符串

            parseJsonResult(response);//解析返回的json字符串
        }
    }

经测试,问题解决。

这个有关于FinalizerWatchdogDaemon的解释ART运行时垃圾收集(GC)过程分析





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值