由于要将方法缓存起来提升性能java
java.lang.IllegalArgumentException: object is not an instance of declaring class
以前个人一篇文章:
https://blog.csdn.net/dataiyangu/article/details/88370206
说的是由于第一次构造出Method的类,和真正执行的时候的对象的类不是同一的。web
通过此次发现:这个错误还和ClassLoader有关系,若是ClassLoader不相同,也会报这个错误。缓存
log.debug("req###########################################+" + req.getClass().getClassLoader().toString());
能够看到两个request的context是不一样的。svg
因此会报如上的错误。性能
固然,解决的办法就是将
classLoader的hashCode+className+methodName 做为key缓存到HashMap中,spa
这个时候可能会报错空指针
由于,有些基础的类确实得不到ClassLoader,而在个人实际状况中,这些类(真的是得不到ClassLoader的状况)不会出现二次访问的状况,因此不须要访问,因此作以下处理便可。.net
ClassLoader classLoader = object.getClass().getClassLoader(); if (classLoader != null) { int classLoaderHash = classLoader.toString().hashCode(); methodId = classLoaderHash+className + methodName; }else{ methodId = className + methodName; }