AndroidRuntime: FATAL EXCEPTION: FinalizerWatchdogDaemon问题解决

本文介绍了一个关于Android应用中FinalizerWatchdogDaemon导致的崩溃问题。该问题表现为在特定时间后程序崩溃,通过使用OKHttp替代原有网络请求框架成功解决了这一问题。

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)过程分析





给定引用主要围绕 Android 项目从 Eclipse 导入 Android Studio 的问题、“E/AndroidRuntime: FATAL EXCEPTION: main” 报错原因及主项目覆盖库项目 xml 导致异常等内容,未提及 “AndroidRuntime 中 RetrofitUtil - th - 1 线程出现 FATAL EXCEPTION” 的解决方案,以下是基于常见的此类异常给出的可能解决办法。 ### 1. 检查网络请求配置 Retrofit 主要用于网络请求,网络配置错误可能导致异常。确保 Retrofit 的基础 URL 配置正确,例如: ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl("https://api.example.com/") .addConverterFactory(GsonConverterFactory.create()) .build(); ``` 同时,检查是否添加了必要的网络权限: ```xml <uses-permission android:name="android.permission.INTERNET" /> ``` ### 2. 处理 JSON 解析错误 如果服务器返回的数据格式与定义的实体类不匹配,可能会引发异常。可以添加日志拦截器来查看服务器返回的具体内容,例如使用 OkHttp 的日志拦截器: ```java OkHttpClient client = new OkHttpClient.Builder() .addInterceptor(new HttpLoggingInterceptor().setLevel(HttpLoggingInterceptor.Level.BODY)) .build(); Retrofit retrofit = new Retrofit.Builder() .baseUrl("https://api.example.com/") .addConverterFactory(GsonConverterFactory.create()) .client(client) .build(); ``` ### 3. 检查异步线程问题 确保所有的 Retrofit 请求都在合适的线程中执行,避免在主线程中进行耗时的网络操作。通常使用 Retrofit 的 Call 接口的 `enqueue` 方法进行异步请求: ```java Call<ResponseModel> call = apiService.getData(); call.enqueue(new Callback<ResponseModel>() { @Override public void onResponse(Call<ResponseModel> call, Response<ResponseModel> response) { if (response.isSuccessful()) { // 处理响应 } else { // 处理错误响应 } } @Override public void onFailure(Call<ResponseModel> call, Throwable t) { // 处理请求失败 } }); ``` ### 4. 异常捕获与日志记录 在代码中添加异常捕获逻辑,并记录详细的错误信息,以便更好地定位问题: ```java Call<ResponseModel> call = apiService.getData(); call.enqueue(new Callback<ResponseModel>() { @Override public void onResponse(Call<ResponseModel> call, Response<ResponseModel> response) { try { if (response.isSuccessful()) { // 处理响应 } else { // 处理错误响应 } } catch (Exception e) { e.printStackTrace(); } } @Override public void onFailure(Call<ResponseModel> call, Throwable t) { t.printStackTrace(); } }); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值