java.lang.NoSuchMethodError: com.xxx.xxx.xxx.po.xxxPo.setXXX(D)V

          近日修改一个功能,很简单,就修改了这个功能的PO实体类的一个属性的数据类型,把double改成Double了,get,set方法也进行了修改,然后把PO的class给替换到正式了。然后就开始出莫名其妙的问题,后台日志没报任何错,但是程序没有走完,没有返回任何信息。我就开始捋代码啊,捋了几遍没发现有什么不对劲的代码啊,很头疼。最后在Tomcat的日志文件里发现了错误,java.lang.NoSuchMethodError: com.xxx.xxx.xxx.po.xxxPo.setXXX(D)V。虽然找到了错误,可是我还是不知道哪里错了,PO的set方法明明就有啊。再次替换PO的class还是不行。最后才发现问题在哪,是new这个PO的manager实现类没有一起替换,虽然它没有修改。然后把manager替换之后,问题解决。

           业务场景是这样的,保存一张表单,controller,manager,具体保存方法是在manager里写的,manager里new了一个PO对象,set值,然后保存。

          错误原因是:我的理解是这样的,manager是依赖PO的,我没有替换manager,所以manager指向的是老的PO,可是我替换了PO的class,所以它找不到了,所以应该把manager也替换成编译后的。

          把这个经历记录一下,让我自己记忆清晰一点,也给头疼此问题的人提供一个排除错误的方法。

你可能感兴趣的:(java)