51Testing软件测试论坛

标题: 关于java常量的踩坑总结 [打印本页]

作者: 快要秃头的娜娜    时间: 2021-7-7 15:33
标题: 关于java常量的踩坑总结
1、背景
在我的日常工作中,时隔几日就会进行一次发版,来解决生产环境遇到的各种bug和优化,但是由于一些日积月累的原因,更新某些项目时,不可以对jar包进行整包替换,通常都是以包内的class单个替换,尽量让这套年迈的系统能够多挺些时日,但是在一次发版过程中,遇到了一点点小问题,我们只修改了常量类,所以当时只更新了这一个类,在测试过程中发现修改内容未生效,经过一番排查后发现是因为常量实用不当引发的问题,下面就针对这次踩坑的经历,讲一下java中的常量以及避坑的措施。

2、什么是常量
常量是指在整个操作过程中其值保持不变的数据,通常在命令或程序中直接给出其值,用做常量的数据类型有数值型、字符型、日期型、逻辑型和货币型等类型。

3、java中的常量
在Java语言中,主要是利用final关键字来定义常量,通常我们会以public static final 来修饰(编译时常量)。

    package com.kevin.test01;

    public class Const
    {
      public static final String sun = "SUN";
      public static final String supperFileType = "exe;jar;class";
    }
4、实例调试
我们先写一个常量使用的一个实例

package com.kevin.test01;

public class Const {
         public static final String sun = "SUN";
         public static final String supperFileType = "exe;jar;class";
}

package com.kevin.test01;

public class Common {
        public static void main(String [] args){
                StringBuffer txt = new StringBuffer();
                txt.append("支持的文件类型");
                txt.append(Const.supperFileType);
                System.out.println(txt.toString());
        }
}
运行结果如下:



我们通过反编译工具jd-gui来反编译这2个class,来看看被编译后的内容是什么样的

先看看Const类的内容,这里没什么问题。



我们再看看引用常量的Common类,我们发现反编译后,在引用常量的地方竟然不是常量名称,而是常量的值,如果我们在代码中有很多地方以这种方式引用常量的话,那就只能对jar包进行整包更新了,而且也增加里出现其他问题的风险,那么怎么规避在无意中挖了这种坑或者踩了这种坑呢。



5、关于常量使用的建议之一
1、在引用常量时不要直接引用常量名,而是再常量类中加入get方法。

package com.kevin.test01;

public class Const {
         static final String sun = "SUN";
         static final String supperFileType = "exe;jar;class";
         public static String getConst(String constName){
            switch(constName){
                    case "sun" :
                    return sun;
                case "supperFileType":
                    return supperFileType;
                    default:
                    return null;
                    }
            }
}

在需要引用常量的地方,我们直接用常量类中的静态方法获取

package com.kevin.test01;

public class Common {
        public static void main(String [] args){
                StringBuffer txt = new StringBuffer();
                txt.append("支持的文件类型");
                txt.append(Const.getConst("supperFileType"));
                System.out.println(txt.toString());
        }
}

以下是反编译后的内容,





反编译后,我们看到引用常量的地方,不再是常量值,而是调用了静态方法,这种方式就可以完美的避开直接引用带来的诸多不确定性问题,还有很多非常好的方法,等后续更文再仔细讲述。

最后小编在学习过程中整理了一些学习资料,可以分享给做软件测试工程师的朋友们,相互交流学习,需要的可以加入我的学习交流群 323432957 或加微dingyu-002即可免费获取Python自动化测开及Java自动化测开学习资料(里面有功能测试、性能测试、python自动化、java自动化、测试开发、接口测试、APP测试等多个知识点的架构资料)




欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2