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