天天看点

为什么类中的常量没有同步过来

集测的时候出现原来的功能不好使的情况(把我急死了);

手机号换绑(接口c)后,查询个人信息(接口i),显示的信息还是老的手机号.

后来看日志,发现接口c 和接口i 调用的ip不同,但是两个接口引用的是同一个常量啊?

我就突然想到了修改常量类之后,接口c 没有重新编译的问题.

为了确认这点,我找运维,请他把这两个接口的service  class文件发给我,我使用jd-gui.exe 反编译,发现这两个接口中的ip确实不同.于是我决定找到问题的源头,我详细问了运维部署项目的流程.集测部署流程如下:

为什么类中的常量没有同步过来

 我就往上追溯到jenkins,于是我就找到负责jenkins 的同事,让她把最近一次jenkins部署的相关class文件发给我,我反编译,发现ip不对.那么问题就不在运维,而是在jenkins了.

而且这个同事把编译的结果清理之后,重新部署,发给我相同的class,我反编译之后,发现ip就对了.

所以出问题的环节锁定在jenkins 了.

于是我让该同事查看jenkins 具体构建代码,结果发现没有调用mvn clean

而且我马上做了一个测试

有两个类,一个是常量类,一个是测试类

常量类:

为什么类中的常量没有同步过来

package test;  

public class constant {  

    public static final string username="黄威";  

}  

 测试类:

为什么类中的常量没有同步过来

public class huangwei {  

    private string myname=constant.username;  

    public static void main(string[] args) {  

        system.out.println(constant.username);  

    }  

 编译之后,反编译huangwei.class

结果如下:

为什么类中的常量没有同步过来

接着我修改constant类,把constant中username的值改为"黄威2222222222222222"

保存之后,执行maven命令:mvn package

为什么类中的常量没有同步过来

maven执行完之后,再次反编译huangwei.class,仍然是:

为什么类中的常量没有同步过来

 根本原因:

因为maven发现huangwei 类没有修改,所以没有重新编译.

但是huangwei 引用的常量修改过了.

解决办法:添加mvn clean

参考: