近日同事在用我们公司自己的缓存框架时,出现了一次noSuchMethodError异常。本来以为是一次简单的jar包冲突,但是却解决了好久。
项目架构是spring-boot 2.0.3版本,
异常信息如下
本来以为分析下是不是有冲突的jar包就能解决问题。但是分析下来发现,整个项目只依赖了一个spring-data-redis 2.0.8.release版本。
并且这个jar里有Boolean delete(Object o)方法。debug的时候无论怎样都进不去这个方法。但是idea的evaluate却可以正常使用。反复查看了多次。发现一个关键的问题。那就是在spring-data-redis-2.0.8.release这个jar,方法的返回的类型是Boolean。但是在异常的地方,
java.lang.NoSuchMethodError: org.springframework.data.redis.core.RedisTemplate.delete(Ljava/lang/Object;)V
却是这么一句异常。熟悉jvm的同学可能已经发现,堆栈信息的最后有个V。这代表这个方法是一个void方法。jvm在方法调用的用的时候,寻找不到这个void的delete方法,所以报了noSuchMethodError。
仔细查看了cache框架引用的spring-data