if语句的数据驱动优化(Java版)

Posted chenyangsocool

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了if语句的数据驱动优化(Java版)相关的知识,希望对你有一定的参考价值。

举个栗子,如果我要输出数字对应的中文描述,我可以用这种方法来写:

int num=2;

if (num==1){
    System.out.println("一");
}
else if (num==2){
    System.out.println("二");
}
else if (num==3){
    System.out.println("三");
}
else if (num==4){
    System.out.println("四");
}
else if (num==5){
    System.out.println("五");
}else {
    System.out.println("其它");
}

 

但是如果有一百个数字,难道你要写一百次的if语句么??所以可以优化成下面这样:

public static String ConvertNumber(int num){
    Map<Integer,String> map=new HashMap<Integer,String>();
    map.put(1,"一");
    map.put(2,"二");
    map.put(3,"三");
    map.put(4,"四");
    map.put(5,"五");
    for (Integer integer:map.keySet()){
        if (integer==num){
            return map.get(integer);
        }
    }
    return "其它";
}

然后在Main函数中直接调用该方法System.out.println(ConvertNumber(num));就可以啦!

显而易见的是,第二种数据驱动的编程方式更为简练,它将数据和逻辑剥离,拓展性好。

比如我想添加一个6对应的六,只要在代码的数据段中添加map.put(6,"六");就可以了。

 

以上是关于if语句的数据驱动优化(Java版)的主要内容,如果未能解决你的问题,请参考以下文章

SQL Select 语句的用法

如何解决大量的if语句或switch case语句?

java中对if的优化

编写代码片段的更简洁的方法

关于mysql驱动版本报错解决,Cause: com.mysql.jdbc.exceptions.jdbc4Unknown system variable ‘query_cache_size(代码片段

PHP条件控制语句之“if语句”