在接口B中调用了接口A中的方法,由于数据库数据的问题导致空指针异常,而发生异常的地方并未在接口A中try catch块中.
此时在接口B中写常规的try catch语句:
try{
......
}catch(e:Exception){
log.message = e.message
}
运行代码后查看记录发现log中并没有记录错误信息message
于是打断点去查看catch到的异常,发现是一堆奇怪的东西…
而 detailMessage 的值为null,难怪没有message的内容.
点开发现undeclaredThrowable是一个java.lang.reflect.UndeclaredThrowableException类型的异常,
而在它里面有一个叫做target的是一个java.lang.reflect.InvocationTargetException类型的异常,真正的错误信息在target里面的detailMessage中.
百度了一下这两个异常,原理这里不再粘贴,解决标题所示问题的方法如下:
将catch到的e强转成UndeclaredThrowable,再获取到它下面的target强转成InvocationTargetException,由于这个异常中没有重写getMessage方法,所以需要先调用getTargetException方法再调用getMessage.
如此则能获取到我们需要的错误信息了.
由于代码中catch处较多,我写了一个方法来获取message并对异常类型做简单处理.
语言为kotlin,此处原理相同,Java写法大同小异就不再补充.
private fun getMessageFromException(e:Exception):String?{
var message:String?=null
if (e is UndeclaredThrowableException){
val target = e.undeclaredThrowable as InvocationTargetException
message = target.targetException.message
}
else
message = e.message
return message
}
完.