在高德地图使用同步方法的过程中,由于粗心大意,虽然创建了单独线程去处理逆地理编码的同步请求,但是在主线程的handler中进行了同步请求,虽然没有报错,但是在以下核心代码中,
try {
address = mGeocodeSearch.getFromLocation(query)
}catch (e: AMapException){
resultCode = e.errorCode
e.printStackTrace()
}
总是捕捉到以下异常,但是使用高德地图异步请求却可以正常返回逆地理编码结果.
com.amap.api.services.core.AMapException: http或socket连接失败 - ConnectionException
1565274197.162 32561-32561/com.xx.xx W/System.err: at com.amap.api.services.a.a.g(BasicHandler.java:167)
1565274197.162 32561-32561/com.xx.xx W/System.err: at com.amap.api.services.a.a.c(BasicHandler.java:116)
1565274197.162 32561-32561/com.xx.xx W/System.err: at com.amap.api.services.a.av.getFromLocation(GeocodeSearchCore.java:86)
1565274197.162 32561-32561/com.xx.xx W/System.err: at com.amap.api.services.geocoder.GeocodeSearch.getFromLocation(GeocodeSearch.java:70)
原本我以为是高德地图的原因,但是经过对已混淆源码中同步代码和异步的大致分析,并没有找到太大差别,经过一番折腾之后,我正打算改同步为异步,突然发现是自己在子线程中用handler包裹了这个同步请求,意味着我是在Ui线程进行了同步请求的操作,在高德sdk进行请求的过程中发生了错误,被误以为是网络异常抛了出来.
在去掉handler的包裹之后,再次运行代码,已经可以正常获取地址